劍指Offer面試題 6 旋轉陣列中的最小數字

2022-04-22 16:31:20 字數 1153 閱讀 5736

題目:把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個遞增排序的陣列的乙個旋轉,輸出旋轉陣列的最小元素。例如陣列為的乙個旋轉,該陣列的最小值為1。
這道題最直觀的解法並不難,從頭到尾遍歷陣列一次,我們就能找出最小的元素。這種思路的時間複雜度顯然是o(n)。但是這個思路沒有利用輸入的旋轉陣列的特性,肯定達不到面試官的要求

我們注意到旋轉之後的陣列實際上可以劃分為兩個排序的子陣列,而且前面的子陣列的元素都大於或者等於後面子陣列的元素。我們還注意到最小的元素剛好是這兩個子陣列的分界線。在排序的陣列中我們可以用二分查詢法實現o(logn)的查詢

#include "

stdio.h

"#include

using

namespace

std;

#include

//遍歷序列,找到最小值

int normalfindminval(int *pstart, int *pend)

pstart++;

}return

min;

}int searchmininrotateaarr_1(int *pstart, int *pend)

if (pend - pstart == 1

)

int *pmid =null;

pmid = pstart + (pend - pstart) / 2

;

if (*pmid >= *pstart && *pmid <= *pend)

if (*pmid >= *pstart)

else

if(*pmid <= *pend)

return

searchmininrotateaarr_1(pstart, pend);}//

找到旋轉陣列中的最小數字

int searchmininrotateaarr(int arr, int

nlen)

int a = ;

int b = ;

int c = ;

void

main()

劍指offer 面試題11 旋轉陣列的最小數字

完整 位址 把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個非遞減排序的陣列的乙個旋轉,輸出旋轉陣列的最小元素。例如陣列為的乙個旋轉,該陣列的最小值為1。note 給出的所有元素都大於0,若陣列大小為0,請返回0。這道題目相對前面的比較複雜,坑比較多 此時用二分法解決,mi...

劍指Offer面試題11 旋轉陣列的最小數字

把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個非減排序的陣列的乙個旋轉,輸出旋轉陣列的最小元素。例如陣列為的乙個旋轉,該陣列的最小值為1。note 給出的所有元素都大於0,若陣列大小為0,請返回0。牛客網ac class solution int left 0,right...

《劍指offer》面試題11 旋轉陣列的最小數字

題目 把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個遞增排序的陣列的乙個旋轉,輸出旋轉陣列的最小元素。例如,陣列為的乙個旋轉,該陣列的最小值為1。分析 我們注意到旋轉之後的陣列實際上可以劃分為兩個排序的子陣列,而且前面子陣列的元素都大於或者等於後面子陣列的元素。和二分查詢...