关闭

Find Minimum in Rotated Sorted Array

标签: ArrayBinary Search
107人阅读 评论(0) 收藏 举报
分类:
//逻辑是否可以再清晰些。
public class Solution {
    public int findMin(int[] nums) {
        if (nums == null || nums.length == 0) {
            return Integer.MIN_VALUE;
        }
        int left = 0;
        int right = nums.length - 1;
        while (left < right) {
            if (nums[left] < nums[right]) {
                return nums[left];
            }
            int mid = left + (right - left) / 2;
            if (mid != 0 && nums[mid] < nums[mid - 1]) {
                return nums[mid];
            }
            if (nums[mid] >= nums[left]) {
                left = mid + 1;
            } else {
                right = mid;
            }
        }
        return nums[left];
    }
}

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:27709次
    • 积分:2365
    • 等级:
    • 排名:第16333名
    • 原创:214篇
    • 转载:2篇
    • 译文:0篇
    • 评论:0条