把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個遞增排序的陣列的乙個旋轉,輸出旋轉陣列的最小元素。例如,陣列 [3,4,5,1,2] 為 [1,2,3,4,5] 的乙個旋轉,該陣列的最小值為1。
示例 1:
輸入:[3,4,5,1,2]
輸出:1
示例 2:
輸入:[2,2,2,0,1]
輸出:0
暴力法沒新意
使用二分法+暴力法
需要注意二分法可能遇到的問題,因為中間的資料可能存在向下躍遷,找到躍遷,就是找到結果,但是二分法不能很快的檢測相鄰,所以需要逐漸查詢
需要注意
//修改迴圈判斷條件
//判斷的是low!=hight
//但是沒有給如果不滿足迴圈後的輸出
//異常二
//更換區間錯誤
//異常三
//mid==low
//說明low和hight相鄰
//low=hight
//異常四
//將low=hight放在迴圈第一節會導致全順序排列的判斷失敗,需要將其放入子判斷中
//異常五
//當low>hight&&mid==hight
//知道else的作用,就是當if修改了資料,之後的判斷又剛好用到該資料,就死亡了
//使用continue跳出本次迴圈
//異常六
//var low, hight, mid int
iflen
(numbers)==0
iflen
(numbers)==1
low =
0 hight =
len(numbers)-1
mid = low +
(hight-low)/2
for low != hight
if numbers[low]
== numbers[hight]
if numbers[low]
> numbers[hight]
if numbers[mid]
> numbers[hight]
if mid == low }}
if low == hight
return-1
}
旋轉陣列最小數字
把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個遞增排序的陣列的乙個旋轉,輸出旋轉陣列的最小元素。例如陣列 為的乙個旋轉,該陣列的最小值為1。code int min int numbers,int length int low 0 int high length 1 in...
旋轉陣列最小數字
旋轉陣列最小數字 劍指offer 二分查詢 題目描述 把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個遞增排序的陣列的乙個旋轉,輸出旋轉陣列的最小元素。解題思路 題目要求找到最小元素,第一反應是排序,但陣列基本有序直接排序浪費效能。結合資料的特點前半部分遞增,後半部分遞減,...
旋轉陣列的最小數字
1.問題描述 把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個遞增排序的陣列的乙個旋轉,輸出該旋轉陣列的最小元素。例如陣列 3,4,5,1,2 為 1,2,3,4,5 的乙個旋轉,該陣列的最小值為1.來自 劍指offer 2.分析 首先我們可以看到原陣列為遞增排序的,並且以...