题解 | #旋转数组的最小数字#

旋转数组的最小数字

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--

全部评论

相关推荐

程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务