剑指offer 06:旋转数组的最小数字
题目描述
把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。
解题代码
二分写法两种形式:
1、缩小范围时,right = mid, left = mid + 1, 取中间值时, mid = (left + right)/2 。
2、缩小范围时,left = mid, right = mid - 1,取中间值时, mid = (left + right + 1)/2 。
public class Solution { public int minNumberInRotateArray(int [] array) { if(array.length == 0) return 0; int left = 0, right = array.length - 1; while(left < right){ int mid = (left + right)/2; if(array[mid] == array[left] && array[mid] == array[right]) right = right - 1; else if(array[mid] <= array[right]) right = mid; else left = mid + 1; } return array[left]; } }


浙公网安备 33010602011771号