33. Search in Rotated Sorted Array
Input: nums = [4,5,6,7,0,1,2], target = 0
Output: 4Input: nums = [4,5,6,7,0,1,2], target = 3
Output: -1// Binary Search
int 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 mid;
if (nums[left] <= nums[mid]) { // [left...mid] is sorted
if (nums[left] <= target && target < nums[mid]) {
right = mid - 1;
} else {
left = mid + 1; // the equal case is handled beforehand
}
} else { // [mid...right] is sorted
if (nums[mid] < target && target <= nums[right]) {
left = mid + 1;
} else {
right = mid - 1;
}
}
}
return -1;
}Previous4. Median of Two Sorted ArraysNext34. Find First and Last Position of Element in Sorted Array
Last updated