算法題:搜索兩條單身狗

技術(shù)群里有人提出一個(gè)算法題:一個(gè)Int型數(shù)組瓶逃,里面的每一個(gè)數(shù)都是成雙成對的束铭,只有一個(gè)數(shù)是單身狗,找出這個(gè)數(shù)厢绝,算法復(fù)雜度<= O(n)

思路很簡單契沫,通過異或運(yùn)算就可以找到這個(gè)數(shù)。

下面昔汉,升級版的算法題來了懈万。

一個(gè)Int型數(shù)組,里面的每一個(gè)數(shù)都是成雙成對的靶病,只有兩個(gè)可憐的單身狗会通,找出這個(gè)兩個(gè)數(shù),時(shí)間復(fù)雜度<= O(n)娄周,空間復(fù)雜度 O(1)涕侈?
答案見下方。


·
·
·
·
·
·
·





·
·
·
·
·
·
·
·
·
·
·
·


bool FindDog() {

    int a=0;
    int b=0;

    const int length = 12;
    int arr[length] = {1,2,3,4,5,6,810,5,4,3,2,1};

    int aXORb =0;
    for (int i=0; i<length; i++) {
        aXORb ^= arr[i];
    }
    //查找兩個(gè)單身狗的異或值煤辨,如果為0裳涛,則說明不存在兩條單身狗木张。
    if( 0 == aXORb){
        printf("數(shù)據(jù)錯(cuò)誤\n");
        return false;
    }

    //假設(shè)異或值為 0010100,則提取出 0000100

    int mask = 0x0;
    int flag = 0;
    while (flag < sizeof(int)) {
        mask = 0x1 << flag;
        int AB = aXORb & mask;
        if (AB>0) {
            break;
        } else {
            flag++;
        }
    }

    if( 0 == mask){
        printf("數(shù)據(jù)錯(cuò)誤\n");
        return false;
    }

    //假設(shè)掩碼為 0000100调违,則兩個(gè)結(jié)果的右數(shù)第3不一致。
    //通過它泻轰,我們拆分?jǐn)?shù)組為分別包含兩個(gè)結(jié)果的數(shù)組(相同的數(shù)必定在同一數(shù)組技肩,兩個(gè)結(jié)果必定在不同數(shù)組),并分別求值

    for (int i=0; i<length; i++) {
        if (arr[i] & mask) {
            a ^= arr[i];
        }else{
            b ^= arr[i];
        }
    }
    printf("?? = %d \n",a);
    printf("?? = %d \n",b);
    
    return true;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末浮声,一起剝皮案震驚了整個(gè)濱河市虚婿,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌泳挥,老刑警劉巖然痊,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異屉符,居然都是意外死亡剧浸,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進(jìn)店門矗钟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來唆香,“玉大人,你說我怎么就攤上這事吨艇」” “怎么了?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵东涡,是天一觀的道長冯吓。 經(jīng)常有香客問我,道長疮跑,這世上最難降的妖魔是什么组贺? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮祖娘,結(jié)果婚禮上锣披,老公的妹妹穿的比我還像新娘。我一直安慰自己贿条,他們只是感情好雹仿,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著整以,像睡著了一般胧辽。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上公黑,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天邑商,我揣著相機(jī)與錄音摄咆,去河邊找鬼。 笑死人断,一個(gè)胖子當(dāng)著我的面吹牛吭从,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播恶迈,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼涩金,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了暇仲?” 一聲冷哼從身側(cè)響起步做,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎奈附,沒想到半個(gè)月后全度,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡斥滤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年将鸵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片佑颇。...
    茶點(diǎn)故事閱讀 40,664評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡咨堤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出漩符,到底是詐尸還是另有隱情一喘,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布嗜暴,位于F島的核電站凸克,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏闷沥。R本人自食惡果不足惜萎战,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望舆逃。 院中可真熱鬧蚂维,春花似錦、人聲如沸路狮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽奄妨。三九已至涂籽,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間砸抛,已是汗流浹背评雌。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工树枫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人景东。 一個(gè)月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓砂轻,卻偏偏與公主長得像,于是被迫代替她去往敵國和親斤吐。 傳聞我的和親對象是個(gè)殘疾皇子搔涝,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評論 2 359

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