题解 | #旋转数组的最小数字#
旋转数组的最小数字
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--