【剑指offer】面试题11:旋转数组的最小数字(java)

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如,数组 [3,4,5,1,2] 为 [1,2,3,4,5] 的一个旋转,该数组的最小值为1。  

示例 1:

输入:[3,4,5,1,2]
输出:1
示例 2:

输入:[2,2,2,0,1]
输出:0

思路:二分查找,注意有重复值,所以当right与mid对应的值相同是,需要执行right--

代码:

class Solution {

    public int minArray(int[] nums) {

        if(nums.length==0)

        {

            return 0;

        }

        int left=0,right=nums.length-1;

        int mid=0;

        while(left<right)

        {

            mid = left+(right-left)/2;

            if(nums[mid]<nums[right])

            {

                right = mid;

            }

            else  if(nums[mid]>nums[right])

            {

                left = mid+1;

            }

            else{

                right--;

            }

        }

        return nums[right];

    }

}

发布了275 篇原创文章 · 获赞 9 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/hx1043116928/article/details/104605043