旋轉(zhuǎn)數(shù)組中的最小數(shù)字

題目描述

把一個數(shù)組最開始的若干個元素搬到數(shù)組的末尾,我們稱之為數(shù)組的旋轉(zhuǎn)围肥。
輸入一個非遞減排序的數(shù)組的一個旋轉(zhuǎn),輸出旋轉(zhuǎn)數(shù)組的最小元素。
例如數(shù)組{3,4,5,1,2}為{1,2,3,4,5}的一個旋轉(zhuǎn)验靡,該數(shù)組的最小值為1。
NOTE:給出的所有元素都大于0吸占,若數(shù)組大小為0晴叨,請返回0凿宾。

問題分析

  • 暴力查找
  • 二分查找

解題思路1

class Solution {
public:
    int minNumberInRotateArray(vector<int> rotateArray) {
        int size = rotateArray.size();
        if(size == 0){
            return 0;
        }//if
        int left = 0,right = size - 1;
        int mid = 0;
        // rotateArray[left] >= rotateArray[right] 確保旋轉(zhuǎn)
        while(rotateArray[left] >= rotateArray[right]){
            // 分界點
            if(right - left == 1){
                mid = right;
                break;
            }//if
            mid = left + (right - left) / 2;
            // rotateArray[left] rotateArray[right] rotateArray[mid]三者相等
            // 無法確定中間元素是屬于前面還是后面的遞增子數(shù)組
            // 只能順序查找
            if(rotateArray[left] == rotateArray[right] && rotateArray[left] == rotateArray[mid]){
                return MinOrder(rotateArray,left,right);
            }//if
            // 中間元素位于前面的遞增子數(shù)組
            // 此時最小元素位于中間元素的后面
            if(rotateArray[mid] >= rotateArray[left]){
                left = mid;
            }//if
            // 中間元素位于后面的遞增子數(shù)組
            // 此時最小元素位于中間元素的前面
            else{
                right = mid;
            }//else
        }//while
        return rotateArray[mid];
    }
private:
    // 順序?qū)ふ易钚≈?    int MinOrder(vector<int> &num,int left,int right){
        int result = num[left];
        for(int i = left + 1;i < right;++i){
            if(num[i] < result){
                result = num[i];
            }//if
        }//for
        return result;
    }
};
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末矾屯,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子初厚,更是在濱河造成了極大的恐慌件蚕,老刑警劉巖孙技,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異排作,居然都是意外死亡牵啦,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門妄痪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來哈雏,“玉大人,你說我怎么就攤上這事衫生∩驯瘢” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵罪针,是天一觀的道長彭羹。 經(jīng)常有香客問我,道長泪酱,這世上最難降的妖魔是什么派殷? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮墓阀,結(jié)果婚禮上毡惜,老公的妹妹穿的比我還像新娘。我一直安慰自己斯撮,他們只是感情好虱黄,可當(dāng)我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著吮成,像睡著了一般橱乱。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上粱甫,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天泳叠,我揣著相機與錄音,去河邊找鬼茶宵。 笑死危纫,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的乌庶。 我是一名探鬼主播种蝶,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼瞒大!你這毒婦竟也來了螃征?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤透敌,失蹤者是張志新(化名)和其女友劉穎盯滚,沒想到半個月后踢械,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡魄藕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年内列,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片背率。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡话瞧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出寝姿,到底是詐尸還是另有隱情移稳,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布会油,位于F島的核電站个粱,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏翻翩。R本人自食惡果不足惜都许,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望嫂冻。 院中可真熱鬧胶征,春花似錦、人聲如沸桨仿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽服傍。三九已至钱雷,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間吹零,已是汗流浹背罩抗。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留灿椅,地道東北人套蒂。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像茫蛹,于是被迫代替她去往敵國和親操刀。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,724評論 2 354