旋转有序数组的二分查找

http://hi.baidu.com/nicker2010/item/4d4f71145532a234b83180a7

总结规律,简化模型

题目都不难,重要的是很敏锐的发现问题的规律。


旋转有序数组的二分搜索,如
int arr[N] = {15,16,19,20,25,1,3,4,5,7,10,14};
查找X = 5

主要思想:

每次根据L和R求出M后,M左边[L, M]和右边[M+1, R]这两部分中至少一个是有序的。

arr[M]和X比较

(1). arr[M]==X,返回M

(2). arr[M] < arr[R],说明右侧有序,当 arr[M]<X<arr[R],则L=M+1,否则R=M-1

(3). arr[M] > arr[L],说明左侧有序,当 arr[L]<X<arr[M],则R=M-1,否则L=M+1

简单代码:

int CirculateBSearch(const int* arr,int N,int x)
{
    int L=0,R=N-1,M;
    while(L <= R)
    {
        M = (L+R)>>1;
        if(arr[M] == x) return M;
        if(arr[M] <= arr[R])//arr[M]右侧是有序的
        {
            if(arr[M]<x && x<=arr[R])//x在有序部分的内部
                L = M+1;
            else R = M-1;
        }
        else//arr[M]左侧是有序的
        {
            if(x<arr[M] && arr[L]<=x)//x在有序部分的内部
                R = M-1;
            else L = M+1;
        }
    }
    return -1;
}

简单测试:

    const int N = 12;
    int X = 5;
    int arr[N] = {15,16,19,20,25,1,3,4,5,7,10,14};
    cout<<"Array : ";
    PrintArray(arr,N);
    int index = CirculateBSearch(arr,N,X);
    if(index < 0) cout<<X<<" is not found in arr.\n";
    else cout<<X<<" is found in arr, index = "<<index<<endl;


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值