题解 | #旋转数组的最小数字#
旋转数组的最小数字
https://www.nowcoder.com/practice/9f3231a991af4f55b95579b44b7a01ba
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param nums int整型一维数组
* @return int整型
*/
public int minNumberInRotateArray (int[] nums) {
// write code here
int l = 0;
int r = nums.length - 1;
while (l < r) {
int m = (l + r) / 2;
System.out.println("m " + m);
if (nums[m] < nums[r]) {
r = m;
System.out.println("nums[m] < nums[r] " + r);
} else if (nums[m] > nums[r] ) {
l = m + 1;
System.out.println("nums[m] > nums[r] " + l);
} else {
r-- ;
System.out.println("nums[m] = nums[r] " + r);
}
}
return nums[l];
}
}
旋转数组:数组最开始是有序的,只是将数据给移动了,数据还是存在部分有序的,如1 2 3 4 5 6
旋转1 : 3 4 5 6 1 2
旋转2: 5 6 1 2 3 4
通过二分法,获取中间值m,对比末尾值
A[m] > a{r} 说明符合旋转一类型,最小值一定在 [m +1,r]中
A[m] < A[r] 最小值在左面数据中,可能m就是最小,所以所在区间[l,m]
如果==,减少数据长度,r--
