81. Search in Rotated Sorted Array II
Input: nums = [2,5,6,0,0,1,2], target = 0
Output: trueInput: nums = [2,5,6,0,0,1,2], target = 3
Output: false// Binary Search
bool search(vector<int>& nums, int target) { // time: O(logn); space: O(1)
int left = 0, right = nums.size() - 1;
while (left <= right) {
int mid = left + (right - left) / 2;
if (nums[mid] == target) return true;
if (nums[left] < nums[mid]) { // 1st half is in order
if (nums[left] <= target && target < nums[mid]) {
right = mid - 1;
} else {
left = mid + 1;
}
} else if (nums[left] > nums[mid]) { // 2nd half is in order
if (nums[mid] < target && target <= nums[right]) {
left = mid + 1;
} else {
right = mid - 1;
}
} else { // handle the case like: [3, 1, 2, 3, 3, 3]
++left;
}
}
return false;
}Last updated