153. 寻找旋转排序数组中的最小值 - 力扣(LeetCode)
思路:
可以看作是题目33. 搜索旋转排序数组-CSDN博客的第一次二分。
就是找到第一个小于nums[0]的位置,可以把数组水平划分为两个部分,上半部分是大于等于nums[0]的,下半部分是小于nums[0]的。也可以看作左半部分是大于等于nums[0]的,右半部分是小于nums[0]的。
总结:
二分的本质不是单调性,是两段性。
代码:
class Solution {
public int findMin(int[] nums) {
int n = nums.length;
int l = 0, r = n - 1;
while(l <= r) {
int mid = l + (r - l)/2;
if(nums[mid] >= nums[0]) {
l = mid + 1;
}
else {
r = mid - 1;
}
}
return l == n ? nums[0] : nums[l];
}
}