旋转数组的最小数字
把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。
输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。
NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。
import java.util.ArrayList;
public class Solution {
public int minNumberInRotateArray(int [] array) {
if(array.length==0){
return 0;
}
// 这个是直接通过循环遍历来找到数组中的最小值
// int min=array[0];
// for(int i=1;i<array.length;i++){
// if(min>array[i]){
// min=array[i];
// }
// }
// return min;
// 下面通过二分法来查找数组中的最小值
int l=0;
int r=array.length-1;
while(l<r){
int mid=l+(r-l)/2;
if(array[mid]>=array[r]){
l=mid+1;
}else{
r=mid;
}
}
return array[l];
}
}

980

被折叠的 条评论
为什么被折叠?



