Skip to content

Latest commit

 

History

History

81-SearchinRotatedSortedArrayII

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

Search in Rotated Sorted Array II

Problem can be found in here!

Solution: Binary Search

def search(nums: List[int], target: int) -> bool:
    left, right = 0, len(nums)-1

    while left <= right:
        while left < right and nums[left] == nums[left+1]:
            left += 1
        while left < right and nums[right] == nums[right-1]:
            right -= 1

        mid = (right+left) // 2
        if nums[mid] == target:
            return True

        if nums[left] <= nums[mid]:
            if nums[left] <= target < nums[mid]:
                right = mid - 1
            else:
                left = mid + 1
        else:
            if nums[mid] < target <= nums[right]:
                left = mid + 1
            else:
                right = mid - 1

    return False

Time Complexity: O(logn), Space Complexity: O(1)