首页 > 编程语言 > 详细

[leetcode]Search in Rotated Sorted Array @ Python

时间:2014-06-09 18:42:54      阅读:394      评论:0      收藏:0      [点我收藏+]

原题地址:https://oj.leetcode.com/problems/search-in-rotated-sorted-array/

题意:

Suppose a sorted array is rotated at some pivot unknown to you beforehand.

(i.e., 0 1 2 4 5 6 7 might become 4 5 6 7 0 1 2).

You are given a target value to search. If found in the array return its index, otherwise return -1.

You may assume no duplicate exists in the array.

解题思路:二分查找的变种。

代码:

bubuko.com,布布扣
class Solution:
    # @param A, a list of integers
    # @param target, an integer to be searched
    # @return an integer
    def search(self, A, target):
        left = 0; right = len(A) - 1
        while left <= right:
            mid = (left + right) / 2
            if target == A[mid]:
                return mid
            if A[mid] >= A[left]:
                if target < A[mid] and target >= A[left]:
                    right = mid - 1
                else:
                    left = mid + 1
            elif A[mid] < A[right]:
                if target > A[mid] and target <= A[right]:
                    left = mid + 1
                else:
                    right = mid - 1
        return -1
bubuko.com,布布扣

 

[leetcode]Search in Rotated Sorted Array @ Python,布布扣,bubuko.com

[leetcode]Search in Rotated Sorted Array @ Python

原文:http://www.cnblogs.com/zuoyuan/p/3777422.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!