博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
旋转有序数组的二分查找
阅读量:4155 次
发布时间:2019-05-25

本文共 898 字,大约阅读时间需要 2 分钟。

总结规律,简化模型

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

旋转有序数组的二分搜索,如

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;

转载地址:http://zveti.baihongyu.com/

你可能感兴趣的文章
详解Java反射机制
查看>>
网站优化之Tomcat启用Gzip压缩
查看>>
Linux下mysql的彻底卸载
查看>>
python爬虫解决极验验证码问题
查看>>
使用JS将table表格导出为excel
查看>>
java调用阿里云短信服务接口
查看>>
idea的个性配置
查看>>
Java获取访问者Ip并限制Ip访问页面
查看>>
Java读取src下配置文件的问题
查看>>
网页加载时waiting(TTFB)时间过长的问题解决
查看>>
Java时间日期相关工具类
查看>>
JS使用OSS上传文件遇到的一些问题
查看>>
个人博客写了两年
查看>>
博客添加评论功能
查看>>
VMware Ubuntu安装教程(详细过程)
查看>>
Java新手的通病
查看>>
Java虚拟机知识汇总,Jvm面试必问
查看>>
LifecycleProcessor not initialized - call ‘refresh‘ before invoking lifecycl
查看>>
js实现选中div内容并复制到剪切板
查看>>
海康威视DS-K1F100-D8E发卡器Java版
查看>>