Reorder List @ LeetCode (Python)
Longest Valid Parentheses @ LeetCode (Python)

Search in Rotated Sorted Array II @ LeetCode (Python)

kitt posted @ 2014年4月08日 17:12 in LeetCode , 2995 阅读

当没有重复元素时, A[left] <= A[mid]表示右边部分是rotated的。当有重复的元素时, A[left] <= A[mid]要分开讨论了, 比如A=[1,3,1,1,1], left = 0, right = 4, mid = 2, 虽然A[left] <= A[mid], 但是rotated的部分在左边。此时A[left] < A[mid]才表示右边部分是rotated,  A[left] == A[mid]时left++即可。

 

When there's no duplicate, A[left] <= A[mid] means the right part is rotated. When there are duplicates, A[left] <= A[mid] is not certain. E.g. A=[1,3,1,1,1], left = 0, right = 4, mid = 2, although A[left] <= A[mid], the left part is rotated. Here A[left] < A[mid] means the right part is rotated, when A[left] == A[mid] just left ++.

class Solution:
    # @param A a list of integers
    # @param target an integer
    # @return a boolean
    def search(self, A, target):
        left, right = 0, len(A) - 1
        while left <= right:
            mid = (left + right) / 2
            if A[mid] == target: return True
            if A[left] < A[mid]: # the right part is rotated
                if A[left] <= target < A[mid]:
                    right = mid - 1
                else:
                    left = mid + 1
            elif A[left] > A[mid]: # the left part is rotated
                if A[mid] < target <= A[right]:
                    left = mid + 1
                else:
                    right = mid - 1
            else: # A[left] == A[mid]
                left += 1
        return False

登录 *


loading captcha image...
(输入验证码)
or Ctrl+Enter