求解旋轉(zhuǎn)數(shù)組的最小數(shù)字
求解旋轉(zhuǎn)數(shù)組的最小數(shù)字
題目描述:
把一個數(shù)組最開始的若干個元素搬到數(shù)組的末尾,我們稱之為數(shù)組的旋轉(zhuǎn)。輸入一個遞增排序的數(shù)組的一個旋轉(zhuǎn),輸出旋轉(zhuǎn)數(shù)組的最小數(shù)組。例如數(shù)組{3,4,5,1,2}是數(shù)組{1,2,3,4,5}的旋轉(zhuǎn)數(shù)組,該數(shù)組的最小值為1。
思路解析:
O(N)的算法
這種算法的思想就是遍歷這個數(shù)組,由于這個數(shù)組是兩部分有序的數(shù)組,因此遍歷這個數(shù)組時當(dāng)后一個數(shù)字小于前一個數(shù)字時,則后一個(即較?。┮欢檎麄€數(shù)組中最小的數(shù)字。
這種算法的思想很簡單,但就是時間復(fù)雜度較大,因此不是很好的算法。
int minNumberInRotateArray(vector<int> rotateArray) { if (rotateArray.empty()) return -1; unsigned int i=0; for (; i<rotateArray.size()-1; i++) { if (rotateArray[i] > rotateArray[i+1]) break; } return rotateArray[i+1]; }
O(logN)的算法
這種算法思想類似于二分查找,首先每次找到數(shù)組中中間的數(shù)字mid,如果mid大于最左端left,說明最小數(shù)在mid的右側(cè)區(qū)間,則改變left,置left為mid;如果mid小于數(shù)組右側(cè)right,說明最小數(shù)在mid的左側(cè)區(qū)間,則改變right為mid….當(dāng)left的數(shù)字小于等于right的數(shù)字時,說明已經(jīng)找到最小數(shù),這個也是循環(huán)結(jié)束的條件
int minNumberInRotateArray(vector<int> rotateArray) { if (rotateArray.empty()) return -1; unsigned int left=0; unsigned int right=rotateArray.size()-1; unsigned int mid=left; while (rotateArray[left] >= rotateArray[right]) { if (right-left == 1) { mid = right; break; } mid = left+((right-left)>>1); if (rotateArray[mid]==rotateArray[left] && rotateArray[right]==rotateArray[mid]) return rotateArray[mid]; if (rotateArray[mid] >= rotateArray[left]) left = mid; else if (rotateArray[mid] <= rotateArray[right]) right = mid; } return rotateArray[mid]; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
上一篇:C語言使用openSSL庫DES模塊實現(xiàn)加密功能詳解
欄 目:C語言
下一篇:數(shù)據(jù)結(jié)構(gòu) 數(shù)組順序存儲詳細介紹
本文標(biāo)題:求解旋轉(zhuǎn)數(shù)組的最小數(shù)字
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1529.html
您可能感興趣的文章
- 01-10求子數(shù)組最大和的解決方法詳解
- 01-10用貪心法求解背包問題的解決方法
- 01-10如何尋找數(shù)組中的第二大數(shù)
- 01-10深入線性時間復(fù)雜度求數(shù)組中第K大數(shù)的方法詳解
- 01-10數(shù)組中求第K大數(shù)的實現(xiàn)方法
- 01-10深入理解數(shù)組指針與指針數(shù)組的區(qū)別
- 01-10c語言字符數(shù)組與字符串的使用詳解
- 01-10解析sizeof, strlen, 指針以及數(shù)組作為函數(shù)參數(shù)的應(yīng)用
- 01-10c語言中用字符串?dāng)?shù)組顯示菜單的解決方法
- 01-10探討C++中數(shù)組名與指針的用法比較分析


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 01-10C#中split用法實例總結(jié)
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-10delphi制作wav文件的方法
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05DEDE織夢data目錄下的sessions文件夾有什