输入:numbers = [3,4,5,1,2]
输出:1
输入:numbers = [2,2,2,0,1]
输出:0
将numbers数组看成左右两个部分
因为numbers是经过有序数组旋转得来的,所以现在就是找右边数组的第一个元素(旋转点)
有序数组问题可以选择使用二分法:i,mid,j
使用二分法判断mid在数组的左部分还是右部分
则 numbers[mid] 和 numbers[j] 进行比较
如果numbers[mid] > numbers[j],则旋转点肯定在mid右边
如果numbers[mid] < numbers[j],则旋转点肯定在mid左边
如果numbers[mid] == numbers[j] ,j- -,既缩小了区间,又不会导致旋转点丢失
public int minArray(int[] numbers) {
int left = 0,right = numbers.length-1;
while (left < right){
int mid = (left+right)/2;
if (numbers[mid] > numbers[right])
left = mid+1;
else if (numbers[mid] < numbers[right])
right = mid;
else
right--;
}
return numbers[left];
}
}