public int findMin(int[] nums) {
int l = 0, r = nums.length - 1;
while (l + 1 < r) {
int mid = l + (r - l) / 2;
if (nums[mid] > nums[r]) l = mid;
else r = mid;
}
return nums[l] > nums[r] ? nums[r] : nums[l];
}
public int findMin(int[] nums) {
int l = 0, r = nums.length - 1;
while (l + 1 < r) {
int mid = l + (r - l) / 2;
if (nums[mid] == nums[r]) r--; // 多加这一步。如果有重复数字,这样可以往前找
else if (nums[mid] > nums[r]) l = mid;
else r = mid;
}
if (nums[l] <= nums[r]) return nums[l];
else return nums[r];
}