码迷,mamicode.com
首页 > 编程语言 > 详细

LeetCode 33 Search in Rotated Sorted Array(在旋转排序数组中搜索)(*)

时间:2015-11-26 21:22:24      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:

翻译

假定一个数组在一个我们预先不知道的轴点旋转。

例如,0 1 2 4 5 6 7可能会变为4 5 6 7 0 1 2。

给你一个目标值去搜索,如果找到了则返回它的索引,否则返回-1。

你可以假定没有重复的元素存在于数组中。

原文

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.

代码

class Solution {
public:
    int search(vector<int>& nums, int target) {
        int l = 0, r = nums.size()-1;
        while (l<=r) {
            int mid = (r-l)/2+l;
            if (nums[mid] == target)
                return mid;
            if (nums[mid] < nums[r]) {
                if (nums[mid]<target && target<=nums[r])
                    l = mid+1;
                else
                    r = mid-1;
            } else {
                if(nums[l]<=target && target<nums[mid])
                    r = mid-1;
                else
                    l = mid+1;
            }
        }
        return -1;
    }
};

LeetCode 33 Search in Rotated Sorted Array(在旋转排序数组中搜索)(*)

标签:

原文地址:http://blog.csdn.net/nomasp/article/details/50059623

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!