33. Search in Rotated Sorted Array

Hill K·2022년 8월 17일
0

Algorithm

목록 보기
2/11

Example 1

Input: nums = [4,5,6,7,0,1,2], target = 0
Output: 4

Example 2

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 

이진탐색 이용

profile
안녕하세요

0개의 댓글