gary@interview:~/interview/coding/81-search-in-rot….md$
$ cat ./coding/81-search-in-rotated-sorted-array-ii.md
[Coding]

81. Search in Rotated Sorted Array II

────────────────────────────────────────────────────────────

81. Search in Rotated Sorted Array II

class Solution:
    def search(self, nums: List[int], target: int) -> bool:
        left = 0
        right = 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 = left + (right - left) //2
            if nums[mid] == target:
                return True
            elif nums[mid] >= nums[left]:
                if nums[left] <= target < nums[mid]:
                    right = mid -1
                else: # nums[left] > target or nums[mid] <= target:
                    left = mid + 1
            else:
                if nums[mid] < target <= nums[right]:
                    left = mid + 1
                else: # target <= nums[mid] or target > nums[right]:
                    right = mid - 1
        return False
--tags#Binary Search
$ ls ./coding/ | grep -v 81-search-in-rotated-sorted-array-ii
265. Paint House II256. Paint House143. Reorder List1762. Buildings With an Ocean View
← cd ../codingcd ~