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

查看5道真题和解析