CODE

class Solution:
    def search(self, nums: List[int], target: int) -> int:
        l, r = 0, len(nums) - 1
        while l <= r:
            mid = (l + r) // 2
            if nums[mid] == target:
                return mid
            # left sorted portion
            if nums[l] <= nums[mid]:
                # number is on the right side OR number is on the right side because of partition
                if target > nums[mid] or target < nums[l]:
                    l = mid + 1
                # number is still in the left sorted part
                else:
                    r = mid - 1
            # Right sorted part
            else:
                # number is on the left side OR number is on left side because of partition
                if target < nums[mid] or target > nums[r]:
                    r = mid - 1
                # number is still in the right part
                else:
                    l = mid + 1
        return -1

Last updated