Input: nums = [4,5,6,7,0,1,2], target = 0
Output: 4
Input: nums = [4,5,6,7,0,1,2], target = 3
Output: -1
1 <= nums.length <= 5000
-104 <= nums[i] <= 104
All values of nums are unique.
nums is an ascending array that is possibly rotated.
-104 <= target <= 104
class Solution:
def search(self, nums: List[int], target: int) -> int:
left, right = 0, len(nums)-1
while left <= right:
mid = (left + right) //2
if nums[mid] == target:
return mid
if nums[left] <= nums[mid]:
if target < nums[left] or target > nums[mid]:
left = mid + 1
else:
right = mid - 1
else:
if target> nums[right] or target < nums[mid]:
right = mid - 1
else:
left = mid + 1
return -1
이진탐색 이용