Median of Two Sorted Arrays

題目來(lái)源
給定兩個(gè)有序數(shù)組颠锉,求其中位數(shù)舍悯,這道題之前做過(guò),而且在微軟面試的時(shí)候還面過(guò)。知道大概是利用二分的方法來(lái)做的横堡,但是寫代碼就是寫不出來(lái)冀泻。
然后就看了下討論區(qū)的大神做法住涉,大神們把兩個(gè)數(shù)組都填充下战惊,N個(gè)元素的數(shù)組變成2N+1長(zhǎng)度。例如1 2 3 變成# 1 # 2 # 3 #但两。
然后這樣的話不管數(shù)組是奇數(shù)還是偶數(shù)長(zhǎng)度處理起來(lái)就都一樣了鬓梅。
代碼非常簡(jiǎn)單,如下谨湘,主要是維持兩個(gè)mid绽快,使得兩個(gè)mid左邊的數(shù)目和右邊的數(shù)目一樣,然后主要看mid2悲关,就是比較短的那個(gè)串谎僻,另一個(gè)的話直接n1+n2-mid2就可以了。
然后就是l1, l2, r1, r2的維持寓辱,需要判斷一下l是否是為0以及r是否是最末尾艘绍。
注意結(jié)果應(yīng)該是double類型。

class Solution {
public:
    double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {
        int n1 = nums1.size(), n2 = nums2.size();
        if (n1 < n2)
            return findMedianSortedArrays(nums2, nums1);
        int lo = 0, hi = 2 * n2;
        while (lo <= hi) {
            int mid2 = (lo + hi) / 2;
            int mid1 = n1 + n2 - mid2;
            int l1 = (mid1 == 0) ? INT_MIN : nums[(mid1 - 1) / 2];
            int l2 = (mid2 == 0) ? INT_MIN : nums[(mid2 - 1) / 2];
            int r1 = (mid1 == n1 * 2) ? INT_MAX : nums[mid1 / 2];
            int r2 = (mid2 == n2 * 2) ? INT_MAX : nums[mid2 / 2];
            if (l1 > r2)
                lo = mid1 + 1;
            else if (l2 > r1)
                hi = mid1 - 1;
            else
                return (max(l1, l2) + min(r1, r2)) / 2;
        }
        return -1;
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末秫筏,一起剝皮案震驚了整個(gè)濱河市诱鞠,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌这敬,老刑警劉巖航夺,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異崔涂,居然都是意外死亡阳掐,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)缭保,“玉大人汛闸,你說(shuō)我怎么就攤上這事∫章睿” “怎么了诸老?”我有些...
    開(kāi)封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)钳恕。 經(jīng)常有香客問(wèn)我别伏,道長(zhǎng),這世上最難降的妖魔是什么忧额? 我笑而不...
    開(kāi)封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任厘肮,我火速辦了婚禮,結(jié)果婚禮上宙址,老公的妹妹穿的比我還像新娘轴脐。我一直安慰自己,他們只是感情好抡砂,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著恬涧,像睡著了一般注益。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上溯捆,一...
    開(kāi)封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天丑搔,我揣著相機(jī)與錄音,去河邊找鬼提揍。 笑死啤月,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的劳跃。 我是一名探鬼主播谎仲,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼刨仑!你這毒婦竟也來(lái)了郑诺?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤杉武,失蹤者是張志新(化名)和其女友劉穎辙诞,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體轻抱,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡飞涂,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片较店。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡士八,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出泽西,到底是詐尸還是另有隱情曹铃,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布捧杉,位于F島的核電站陕见,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏味抖。R本人自食惡果不足惜评甜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望仔涩。 院中可真熱鬧忍坷,春花似錦、人聲如沸熔脂。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)霞揉。三九已至旬薯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間适秩,已是汗流浹背绊序。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留秽荞,地道東北人骤公。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像扬跋,于是被迫代替她去往敵國(guó)和親阶捆。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

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