經(jīng)典算法應(yīng)用之四(下)---百度面試題

首先來看題目要求:
在一個(gè)數(shù)組中除兩個(gè)數(shù)字只出現(xiàn)1次外歼培,其它數(shù)字都出現(xiàn)了2次檩淋, 要求盡快找出這兩個(gè)數(shù)字漾稀。
考慮下這個(gè)題目的簡(jiǎn)化版——數(shù)組中除一個(gè)數(shù)字只出現(xiàn)1次外抵代,其它數(shù)字都成對(duì)出現(xiàn)腾节,要求盡快找出這個(gè)數(shù)字。這個(gè)題目在之前的《經(jīng)典排序算法應(yīng)用之4(中)---基本位操作之算法篇
》中的“位操作趣味應(yīng)用”中就已經(jīng)給出解答了。根據(jù)異或運(yùn)算的特點(diǎn)案腺,直接異或一次就可以找出這個(gè)數(shù)字庆冕。
現(xiàn)在數(shù)組中有兩個(gè)數(shù)字只出現(xiàn)1次,直接異或一次只能得到這兩個(gè)數(shù)字的異或結(jié)果劈榨,但光從這個(gè)結(jié)果肯定無法得到這個(gè)兩個(gè)數(shù)字访递。因此我們來分析下簡(jiǎn)化版中“異或”解法的關(guān)鍵點(diǎn),這個(gè)關(guān)鍵點(diǎn)也相當(dāng)明顯——數(shù)組只能有一個(gè)數(shù)字出現(xiàn)1次同辣。
設(shè)題目中這兩個(gè)只出現(xiàn)1次的數(shù)字分別為A和B拷姿,如果能將A,B分開到二個(gè)數(shù)組中旱函,那顯然符合“異或”解法的關(guān)鍵點(diǎn)了响巢。因此這個(gè)題目的關(guān)鍵點(diǎn)就是將A,B分開到二個(gè)數(shù)組中棒妨。由于A踪古,B肯定是不相等的,因此在二進(jìn)制上必定有一位是不同的靶衍。根據(jù)這一位是0還是1可以將A灾炭,B分開到A組和B組。而這個(gè)數(shù)組中其它數(shù)字要么就屬于A組颅眶,要么就屬于B組蜈出。再對(duì)A組和B組分別執(zhí)行“異或”解法就可以得到A,B了涛酗。而要判斷A铡原,B在哪一位上不相同,只要根據(jù)A異或B的結(jié)果就可以知道了商叹,這個(gè)結(jié)果在二進(jìn)制上為1的位都說明A燕刻,B在這一位上是不相同的。
比如int a[] = {1, 1, 3, 5, 2, 2}
整個(gè)數(shù)組異或的結(jié)果為3^5即 0x0011 ^ 0x0101 = 0x0110
對(duì)0x0110剖笙,第1位(由低向高卵洗,從0開始)就是1。因此整個(gè)數(shù)組根據(jù)第1位是0還是1分成兩組弥咪。
a[0] =1 0x0001 第一組
a[1] =1 0x0001 第一組
a[2] =3 0x0011 第二組
a[3] =5 0x0101 第一組
a[4] =2 0x0010 第二組
a[5] =2 0x0010 第二組
第一組有{1, 1, 5}过蹂,第二組有{3, 2, 3},明顯對(duì)這二組分別執(zhí)行“異或”解法就可以得到5和3了聚至。
分析至些酷勺,相信代碼不難寫出,下面給出完整的源代碼:

// 百度面試題  
//數(shù)組中除兩個(gè)數(shù)字外扳躬,其它數(shù)字都出現(xiàn)了次脆诉。要求盡可能快的找出這兩個(gè)數(shù)字  
void FindTwoNotRepeatNumberInArray(int *a, int n, int *pN1, int *pN2)  
{  
    int i, j, temp;  
      
    //計(jì)算這兩個(gè)數(shù)的異或結(jié)果  
    temp = 0;  
    for (i = 0; i < n; i++)  
        temp ^= a[i];  
      
    // 找第一個(gè)為1的位  
    for (j = 0; j < sizeof(int) * 8; j++)  
        if (((temp >> j) & 1) == 1)  
            break;  
  
    // 第j位為1,說明這兩個(gè)數(shù)字在第j位上是不相同的  
    // 由此分組即可  
    *pN1 = 0, *pN2 = 0;  
    for (i = 0; i < n; i++)  
        if (((a[i] >> j) & 1) == 0)  
            *pN1 ^= a[i];  
        else  
            *pN2 ^= a[i];  
}  
void PrintfArray(int a[], int n)  
{  
    for (int i = 0; i < n; i++)  
        printf("%d ", a[i]);  
    putchar('\n');  
}  
int main()  
{  
    const int MAXN = 10;  
    //int a[MAXN] = {1, 2, 7, 5, 100,  100, 6, 1, 2, 5};  
    int a[MAXN] = {1, 2, 3, 4, 1,  2, 3, 4, 0, 5};  
  
    printf("數(shù)組為: \n");  
    PrintfArray(a, MAXN);  
  
    int nNotRepeatNumber1, nNotRepeatNumber2;  
    FindTwoNotRepeatNumberInArray(a, MAXN, &nNotRepeatNumber1, &nNotRepeatNumber2);  
    printf("兩個(gè)不重復(fù)的數(shù)字分別為: %d %d\n", nNotRepeatNumber1, nNotRepeatNumber2);  
    return 0;  
}  

運(yùn)行結(jié)果如下所示:


推薦閱讀:
經(jīng)典算法應(yīng)用之一----歸并排序(微軟筆試題)
經(jīng)典算法應(yīng)用之二----基數(shù)排序(google筆試題)
經(jīng)典算法應(yīng)用之三----應(yīng)用二中題目的升華
經(jīng)典算法應(yīng)用之四(上)---基本位操作之算法篇
經(jīng)典算法應(yīng)用之四(中)---基本位操作之算法篇
經(jīng)典算法應(yīng)用之四(下)---百度面試題
經(jīng)典算法應(yīng)用之五---隨機(jī)生成和為S的N個(gè)正整數(shù)
經(jīng)典算法應(yīng)用之六---過橋問題和過河問題
經(jīng)典算法應(yīng)用之七----10億數(shù)據(jù)中取最大的100個(gè)數(shù)據(jù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末甚亭,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子击胜,更是在濱河造成了極大的恐慌亏狰,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件潜的,死亡現(xiàn)場(chǎng)離奇詭異骚揍,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)啰挪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門信不,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人亡呵,你說我怎么就攤上這事抽活。” “怎么了锰什?”我有些...
    開封第一講書人閱讀 162,931評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵下硕,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我汁胆,道長(zhǎng)梭姓,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,218評(píng)論 1 292
  • 正文 為了忘掉前任嫩码,我火速辦了婚禮誉尖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘铸题。我一直安慰自己铡恕,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評(píng)論 6 388
  • 文/花漫 我一把揭開白布丢间。 她就那樣靜靜地躺著探熔,像睡著了一般。 火紅的嫁衣襯著肌膚如雪烘挫。 梳的紋絲不亂的頭發(fā)上诀艰,一...
    開封第一講書人閱讀 51,198評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音饮六,去河邊找鬼其垄。 笑死,一個(gè)胖子當(dāng)著我的面吹牛喜滨,可吹牛的內(nèi)容都是我干的捉捅。 我是一名探鬼主播撤防,決...
    沈念sama閱讀 40,084評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼虽风,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼棒口!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起辜膝,我...
    開封第一講書人閱讀 38,926評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤无牵,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后厂抖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體茎毁,經(jīng)...
    沈念sama閱讀 45,341評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評(píng)論 2 333
  • 正文 我和宋清朗相戀三年忱辅,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了七蜘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,731評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡墙懂,死狀恐怖橡卤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情损搬,我是刑警寧澤碧库,帶...
    沈念sama閱讀 35,430評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站巧勤,受9級(jí)特大地震影響嵌灰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜颅悉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評(píng)論 3 326
  • 文/蒙蒙 一沽瞭、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧签舞,春花似錦秕脓、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至搂鲫,卻和暖如春傍药,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背魂仍。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工拐辽, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人擦酌。 一個(gè)月前我還...
    沈念sama閱讀 47,743評(píng)論 2 368
  • 正文 我出身青樓俱诸,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親赊舶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子睁搭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容