劍指offer—面試題11:旋轉(zhuǎn)數(shù)組的最小數(shù)字

把一個(gè)數(shù)組最開(kāi)始的若干個(gè)元素搬到數(shù)組的末尾否彩,我們稱之為數(shù)組的旋轉(zhuǎn)。輸入一個(gè)遞增排序的數(shù)組的一個(gè)旋轉(zhuǎn)托享,輸出旋轉(zhuǎn)數(shù)組的最小元素其兴。例如顶瞒,數(shù)組 [3,4,5,1,2] 為 [1,2,3,4,5] 的一個(gè)旋轉(zhuǎn),該數(shù)組的最小值為1元旬。

最簡(jiǎn)單的方法就是遍歷榴徐,直接遍歷一次數(shù)組找到其中的最小值,時(shí)間復(fù)雜度O(n)法绵。

算法一:

   func minArray(_ numbers: [Int]) -> Int {
        guard numbers.count > 0 else {
            return  -1
        }
        var min = numbers[0]
        for num in 1..<numbers.count {
            if min > numbers[num] {
                min =  numbers[num]
            }
        }
        return min
    }

算法一是一種暴力的解法箕速,我們可以根據(jù)旋轉(zhuǎn)數(shù)組的特性來(lái)優(yōu)化酪碘,旋轉(zhuǎn)后的數(shù)組實(shí)際上可以劃分為兩個(gè)排序好的子數(shù)組朋譬。而且前面的子數(shù)組元素都大于后面子數(shù)組的元素。而最小元素是這兩個(gè)子數(shù)組的分界線兴垦。在排序的數(shù)組查找元素我們可以通過(guò)二分查找提供性能徙赢。該題給出的數(shù)組一定程度上也是排序的字柠,所以也可以通過(guò)二分查找來(lái)尋找最小元素。

在二分查找的每一步中狡赐,左邊界為low窑业,右邊界為high,區(qū)間的中點(diǎn)為 indexMid枕屉,最小值就在該區(qū)間內(nèi)常柄。我們將中軸元素 numbers[indexMid]與右邊界元素 numbers[high] 進(jìn)行比較,可能會(huì)有以下的三種情況:

第一種情況是 numbers[indexMid]<numbers[high]搀擂。這說(shuō)明numbers[indexMid]是最小值右側(cè)的元素西潘,因此我們可以忽略二分查找區(qū)間的右半部分。

第二種情況是 numbers[indexMid]>numbers[high]哨颂。這說(shuō)明 numbers[indexMid]是最小值左側(cè)的元素喷市,因此我們可以忽略二分查找區(qū)間的左半部分。

第三種情況是 numbers[indexMid]==numbers[high]威恼。如下圖所示品姓,由于重復(fù)元素的存在,我們并不能確定numbers[indexMid]究竟在最小值的左側(cè)還是右側(cè)箫措,因此我們不能莽撞地忽略某一部分的元素腹备。我們唯一可以知道的是,由于它們的值相同蒂破,所以無(wú)論numbers[high]是不是最小值馏谨,都有一個(gè)它的「替代品」numbers[indexMid],因此我們可以忽略二分查找區(qū)間的右端點(diǎn)附迷。

算法二:

 func minArray(_ numbers: [Int]) -> Int {
    var low = 0
    var high = numbers.count - 1
    
    while low < high {
        let indexMid = low + (high - low)/2
        
        if numbers[indexMid] < numbers[high] {
            high = indexMid
        }else if numbers[indexMid] > numbers[high] {
            low = indexMid + 1
        }else {
            high -= 1
        }
    }
    
    return numbers[low]
}

時(shí)間復(fù)雜度:平均時(shí)間復(fù)雜度為 O(\log n)O(logn)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末惧互,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子喇伯,更是在濱河造成了極大的恐慌喊儡,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,546評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件稻据,死亡現(xiàn)場(chǎng)離奇詭異艾猜,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)捻悯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門匆赃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人今缚,你說(shuō)我怎么就攤上這事算柳。” “怎么了姓言?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,911評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵瞬项,是天一觀的道長(zhǎng)蔗蹋。 經(jīng)常有香客問(wèn)我,道長(zhǎng)囱淋,這世上最難降的妖魔是什么猪杭? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,737評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮妥衣,結(jié)果婚禮上皂吮,老公的妹妹穿的比我還像新娘。我一直安慰自己税手,他們只是感情好涮较,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著冈止,像睡著了一般狂票。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上熙暴,一...
    開(kāi)封第一講書(shū)人閱讀 51,598評(píng)論 1 305
  • 那天闺属,我揣著相機(jī)與錄音,去河邊找鬼周霉。 笑死掂器,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的俱箱。 我是一名探鬼主播国瓮,決...
    沈念sama閱讀 40,338評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼狞谱!你這毒婦竟也來(lái)了乃摹?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,249評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤跟衅,失蹤者是張志新(化名)和其女友劉穎孵睬,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體伶跷,經(jīng)...
    沈念sama閱讀 45,696評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡掰读,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了叭莫。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蹈集。...
    茶點(diǎn)故事閱讀 40,013評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖雇初,靈堂內(nèi)的尸體忽然破棺而出拢肆,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,731評(píng)論 5 346
  • 正文 年R本政府宣布善榛,位于F島的核電站,受9級(jí)特大地震影響呻畸,放射性物質(zhì)發(fā)生泄漏移盆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評(píng)論 3 330
  • 文/蒙蒙 一伤为、第九天 我趴在偏房一處隱蔽的房頂上張望咒循。 院中可真熱鬧,春花似錦绞愚、人聲如沸叙甸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,929評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)裆蒸。三九已至,卻和暖如春糖驴,著一層夾襖步出監(jiān)牢的瞬間僚祷,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,048評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工贮缕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留辙谜,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,203評(píng)論 3 370
  • 正文 我出身青樓感昼,卻偏偏與公主長(zhǎng)得像装哆,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子定嗓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評(píng)論 2 355

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