Binary search
Binary Search
Shrinkage Template
class Solution {
public int findMin(int[] nums) {
// Corner case
if (nums.length == 0) return -1;
if (nums.length == 1) return nums[0];
if (nums[0] < nums[nums.length -1]) return nums[0];
// Narrow the range
// Key: 1) left + 1 < right 2) right = mid;left = mid;
while (left + 1 < right) {
int mid = left + (right - left) / 2;
if (nums[mid] < nums[mid-1]) return nums[mid];
if (nums[mid] > nums[0]) {
left = mid;
} else if (nums[mid] < nums[0]) {
right = mid;
} else {
if (nums[mid] <= nums[left]){
left++;
} else {
right--;
}
}
}
// Determine left and right
if (nums[left] < nums[right]) {
return nums[left];
} else {
return nums[right];
}
}
}Expand Template
Binary Serarch in Matrix
Double binary search
Last updated