码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C++第十单元 查找与检索10.1 顺序查找10.2 二分查找


    目录

    第十单元 查找与检索

    10.1 顺序查找

    10.2 二分查找!

    (1) 普通的二分查找(非递归)

    (2) 二分查找求下界

    (3) 二分查找求上界


    第十单元 查找与检索

    10.1 顺序查找

    1. int find(int *a, int x, int y, int v)
    2. {
    3. for (int i=x; i<=y; i++)
    4. if (a[i]==v) return true;
    5. return false;
    6. }

    10.2 二分查找!

    注意:
     必须使用顺序存储结构,不能使用链表。
     要查找的线性表必须是有序的。
     一般情况下,“使最大值最小”和数以十万计的数据规模暗示着你:问题要用二分法解决。

    (1) 普通的二分查找(非递归)

    将在 a 的区间[x,y)内寻找 v。

    1. int bsearch(int *a, int x, int y, int v)
    2. {
    3. while (x<y) // 注意:不要写成“x<=y”,否则会死循环!
    4. {
    5. int mid=x+(y-x)/2;
    6. if (v==a[mid])
    7. return mid;
    8. else if (v<a[mid])
    9. y=mid;
    10. else
    11. x=mid+1; // 注意:不要忘记加1!
    12. }
    13. return -1; // 找不到
    14. }

    (2) 二分查找求下界

    下面函数会寻找 a 的区间[x,y)中大于等于 v 的第一个数,使得 v 插入到 a 中对应位置,然后 a 还是一个有序的数组

    1. int lower_bound(int *a, int x, int y, int v)
    2. {
    3. while (x<y)
    4. {
    5. int mid=x+(y-x)/2;
    6. /*
    7. v==a[mid]:至少找到一个,但前面可能还有。
    8. v<a[mid]:不能在mid的后面
    9. v>a[mid]:mid和前面都不可以。
    10. */
    11. if (v<=a[mid]) y=mid; else x=mid+1;
    12. }
    13. return x;
    14. }

    (3) 二分查找求上界

    函数应该寻找寻找 a 的区间[x,y)小于等于 v 的最后一个数,使得 v 插入到 a 中对应位置,然后 a 还是一个有序的数组。
    只需对(2)中代码进行如下修改:

    1. int upper_bound(int *a, int x, int y, int v)
    2. {
    3. while (x<y)
    4. {
    5. int mid=x+(y-x)/2;
    6. /*
    7. v==a[mid]:至少找到一个,但右边可能还有。
    8. v<a[mid]:mid和后面都不可以。
    9. v>a[mid]:不能在mid的前面。
    10. */
    11. if (v>=a[mid]) x=mid; else y=mid-1;
    12. }
    13. return y;
    14. }

  • 相关阅读:
    Codeforces Round 903 (Div. 3)
    10.力扣c++刷题-->罗马数字转整数
    2.Linux系统管理(vi和vim的使用)
    微调中文bert训练时采用CPU跑?
    大学英语六级单词记录
    家里照片都看不清了怎么办?教你三招修复旧照片
    ViT-L-14.pt下载load checkpoint from xxx
    uni-app 、Spring Boot 、ant Design 打造的一款跨平台包含小说(仿真翻页、段落听书)、短视频、壁纸等功能含完备后台管理的移动应用
    C Primer Plus(6) 中文版 第8章 字符输入/输出和输入验证 8.5 创建更友好的用户界面
    SpringCloud:网关gateway
  • 原文地址:https://blog.csdn.net/zhengheda/article/details/125621202
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号