码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode] Search in Rotated Sorted Array II 二分搜索

时间:2015-01-22 01:40:55      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:

Follow up for "Search in Rotated Sorted Array":
What if duplicates are allowed?

Would this affect the run-time complexity? How and why?

Write a function to determine if a given target is in the array.

 

Hide Tags
 Array Binary Search
 
  这个是在 前一道的基础上改过来的,主要是 left middle right 相同的时候,递归为左右部分的并,其他部分不变:
class Solution {
public:
    bool search(int A[], int n, int target) {
        if(n==1)    return A[0]==target?true:false;
        return help(A,0,n-1,target);
    }
    int help(int* & A,int l,int r,int &target)
    {
        if(target<A[l]&&target>A[r])    return false;
        if(target==A[l])    return true;
        if(target==A[r])    return true;
        if(r-l==1)  return false;
        int m = (l+r) /2;
        if(target==A[m])    return true;
        if(A[l]<A[m]){
            if(A[l]<target&&target<A[m])    return help(A,l,m,target);
            return help(A,m,r,target);
        }
        else if(A[l]>A[m]){
            if(A[m]<target&&target<A[r])    return help(A,m,r,target);
            return help(A,l,m,target);
        }
        else{
            return help(A,l,m,target)||help(A,m,r,target);
        }
    }
};

 

[LeetCode] Search in Rotated Sorted Array II 二分搜索

标签:

原文地址:http://www.cnblogs.com/Azhu/p/4240540.html

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