旋轉陣列的最小數字

2021-10-20 16:37:03 字數 1425 閱讀 1112

把乙個陣列最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入乙個遞增排序的陣列的乙個旋轉,輸出旋轉陣列的最小元素。例如,陣列 [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.分析 首先我們可以看到原陣列為遞增排序的,並且以...