二、STL中的二分查找算法

1.binary_search

2.lower_bound

3.upper_bound

记得#include<algorithm>!

前言:

  在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标记了出来。

1.1用binary_search进行二分查找(用法一)

在从小到大排好序的基本类型数组上进行二分查找

  binary_search(数组名+n1, 数组名+n2,值);

  n1和n2都是int类型表达式,可以包含变量

  如果n1=0,则 + n1可以不写(这几点和前面sort一样)

  查找区间为下标范围为[n1,n2)的元素,下标为n2的元素不在查找区间内,在该区间内查找“等于”值的元素,返回值为true(找 到)或false(没找到)。(返回值不是位置哦)

等于的含义:a等于b <=> a<b和b<a都不成立。

不是a==b!

1.2用binary_search进行二分查找(用法二)

在用自定义排序规则排好序的、元素为任意的T类型的数组中进行二分查找。

  binary_search(数组名+n1, 数组名+n2, 值, 排序规则结构名());

  n1和n2都是int类型表达式,可以包含变量

  如果n1=0,则 + n1可以不写

  查找区间为下标范围为[n1,n2)的元素,下标为n2的元素不在查找区间内,在该区间内查找“等于”值的元素,返回值为true(找 到)或false(没找到)。

查找时的排序规则,必须和排序时的规则一致!

也不是说排序规则不一样就一定找不到,有可能找到,但是找到的结果并没有意义,说不定就是运气好找到了。

等于的含义:a等于b <=> a<b和b<a都不成立。

样例:

 1 struct Rule//按个位数从小到大排
2 {
3     bool operator()(const int & a1, const int & a2)const{
4         return a1%10 < a2%10;
5     }
6 };
7 void Print(int a[],int size)
8 {
9     for (int i = 0; i < size; i++)
10     {
11         cout<<a[i]<<",";
12     }
13     cout<<endl;
14 }
15
16 int main(int argc, char const *argv[])
17 {
18     int a[] = {12,45,3,98,21,7};
19     sort(a,a+sizeof(a)/sizeof(int));//从小到大排序
20     Print(a,sizeof(a)/sizeof(int));//结果:3,7,12,21,45,98,
21     cout<<"result:"<<binary_search(a,a+6,12)<<endl;//结果:1
22     cout<<"result:"<<binary_search(a,a+6,77)<<endl;//结果:0
23     sort(a,a+6,Rule());
24     Print(a,6);//结果:
25     cout<<"result:"<<binary_search(a,a+6,7)<<endl;//结果:0//其实能找到结果,但是这是没意义的,运气好找到罢了。
26     cout<<"result:"<<binary_search(a,a+6,8,Rule())<<endl;//结果:1
27     //这个结果是1,因为'='的含义是a在b前面和b在a前面都不成立,不是“==”!这里其实找到的是98。
28     return 0;
29 }

样例

2.1用lower_bound二分查找下界(用法一)

在对元素类型为T的从小到大排好序的基本类型的数组中进行查找

  T * lower_bound(数组名+n1, 数组名+n2, 值);

  返回一个指针 T * p;

*p 是查找区间里下标最小的,大于等于值的元素。如果找不到,p指向下标为n2的元素。(反正n2不在查找区间内,要是要写判断可以用这个作为依据)

2.2用lower_bound二分查找下界(用法二)

在元素为任意的T类型、按照自定义排序规则排好序的数组中进行查找

  T * lower_bound(数组名+n1, 数组名+n2, 值, 排序规则名());

  返回一个指针 T * p;

*p是查找区间里下标最小的,按自定义排序规则,可以排在“值”后面的元素。如果找不到,p指向下标为n2的元素。

3.1用upper_bound二分查找上界(用法一)

在对元素类型为T的从小到大排好序的基本类型的数组中进行查找

  T * upper_bound(数组名+n1, 数组名+n2, 值);

  返回一个指针 T * p;

*p 是查找区间里下标最小的,大于值的元素。如果找不到,p指向下标为n2的元素。(这里是大于,不要和前面弄混了)

3.2用upper_bound二分查找上界(用法二)

在元素为任意的T类型、按照自定义排序规则排好序的数组中进行查找

  T * upper_bound(数组名+n1, 数组名+n2, 值, 排序规则名());

  返回一个指针 T * p;

*p是查找区间里下标最小的,按自定义排序规则,必须排在“值”后面的元素。如果找不到,p指向下标为n2的元素。(这里是必须排在值后面的元素,相对来说,lower_bound是可以排在值后面,有可能等于,但是这个就不可能等于了,详情可以看样例)

样例:(这个样例挺全,各种情况都有)

 1 //lower_bound是找到的下标最小的,按排序规则,大于等于值的元素
2 //upper_bound是找到的下标最小的,按排序规则,必须排在值后面的元素
3 //两个都是找不到就指向下标为n2的元素
4 struct Rule//按个位数从小到大排
5 {
6     bool operator()(const int & a1, const int & a2)const{
7         return a1%10 < a2%10;
8     }
9 };
10 void Print(int a[],int size)
11 {
12     for (int i = 0; i < size; i++)
13     {
14         cout<<a[i]<<",";
15     }
16     cout<<endl;
17 }
18
19 int main(int argc, char const *argv[])
20 {
21     int a[NUM] = {12,5,3,5,98,21,7};
22     sort(a,a+sizeof(a)/sizeof(int));//从小到大排序
23     Print(a,sizeof(a)/sizeof(int));//结果:3,5,5,7,12,21,98
24     int *p = lower_bound(a,a+NUM,5);
25     cout<<*p<<","<<p-a<<endl;//结果:5,1
26     p = upper_bound(a,a+NUM,5);
27     cout<<*p<<endl;//结果:7
28     cout<<*upper_bound(a,a+NUM,13)<<endl;//结果:21
29     //这里可以看见不用查找数组内存在的元素也有返回值,当然,这里用binary_search()就会返回false了
30     sort(a,a+NUM,Rule());
31     Print(a,NUM);//结果:21,12,3,5,5,7,98,
32     cout<<* lower_bound(a,a+NUM,16,Rule())<<endl;//结果:7
33     cout<< lower_bound(a,a+NUM,25,Rule())-a<<endl;//结果:3//这里结果是下标
34     cout<< upper_bound(a,a+NUM,18,Rule())-a<<endl;//结果:7//这里结果也是下标,毕竟没找到
35     if (upper_bound(a,a+NUM,18,Rule())==a+NUM)
36     {
37         cout<<"not found"<<endl;//not found,这里是一个例子,如何判断没有找到
38     }
39     cout<<*upper_bound(a,a+NUM,5,Rule())<<endl;//结果:7
40     cout<<*upper_bound(a,a+NUM,4,Rule())<<endl;//结果:5
41     return 0;
42 }

样例

后记:

又学完一节,不得不说STL标准库确实好用,但是平常记不记得用就是个难题了,很多时候我们的思维都固化了,勇敢的尝试新事物有助于我们能力的提升(指想得到用刚学的STL标准库),而在这跳出舒适区的过程中,我们也会收获成长的快乐,总之感谢大家读到这里,我run了,祝大家健康快乐吉祥如意恭喜发财学业有成早生贵子,以及头发茂密,下篇博客再见拜拜。

C++STL标准库学习笔记(二)二分查找的更多相关文章

  1. C++STL标准库学习笔记(三)multiset

    C++STL标准库学习笔记(三)multiset STL中的平衡二叉树数据结构 前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标 ...

  2. C++STL标准库学习笔记(一)sort

    前言: 近来在学习STL标准库,做一份笔记并整理好,方便自己梳理知识.以后查找,也方便他人学习,两全其美,快哉快哉! 这里我会以中国大学慕课上北京大学郭炜老师的<程序设计与算法(一)C语言程序设 ...

  3. C++STL标准库学习笔记(五)set

    前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标记了出来,这一篇后面主要都是我的记录了,为了防止大片蓝色字体出现,后面就不改蓝色 ...

  4. C++STL标准库学习笔记(四)multiset续

    自定义排序规则的multiset用法 前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标记了出来,只不过这一次的笔记主要是我的补充 ...

  5. python3.4学习笔记(二十三) Python调用淘宝IP库获取IP归属地返回省市运营商实例代码

    python3.4学习笔记(二十三) Python调用淘宝IP库获取IP归属地返回省市运营商实例代码 淘宝IP地址库 http://ip.taobao.com/目前提供的服务包括:1. 根据用户提供的 ...

  6. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  7. [Firefly引擎][学习笔记二][已完结]卡牌游戏开发模型的设计

    源地址:http://bbs.9miao.com/thread-44603-1-1.html 在此补充一下Socket的验证机制:socket登陆验证.会采用session会话超时的机制做心跳接口验证 ...

  8. numpy, matplotlib库学习笔记

    Numpy库学习笔记: 1.array()   创建数组或者转化数组 例如,把列表转化为数组 >>>Np.array([1,2,3,4,5]) Array([1,2,3,4,5]) ...

  9. STL标准库-算法-常用算法

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 介绍11种STL标准库的算法,从这11种算法中总结一下算法的基本使用 1.accumulate() 累加 2.for_each( ...

随机推荐

  1. 编解码再进化:Ali266 与下一代视频技术

    过去的一年见证了人类百年不遇的大事记,也见证了多种视频应用的厚积薄发.而因此所带来的视频数据量的爆发式增长更加加剧了对高效编解码这样的底层硬核技术的急迫需求. 新视频编解码标准 VVC 定稿不久之后, ...

  2. 中文NER的那些事儿5. Transformer相对位置编码&TENER代码实现

    这一章我们主要关注transformer在序列标注任务上的应用,作为2017年后最热的模型结构之一,在序列标注任务上原生transformer的表现并不尽如人意,效果比bilstm还要差不少,这背后有 ...

  3. XenServer删除ISO存储!

    1.用命令 df -hal 可以看到 ISO库是使用了10G的硬盘的 2.下面开始直接右键删除ISO,但看到资源还是占用着10G的 3.如果想把这10G的硬盘资源空出来的话,只要复制前面查找到挂载的路 ...

  4. [luogu5438]记忆

    令$f(x)=\frac{x}{\max_{k^{2}|x}k^{2}}$,最优解即将$f(l),f(l+1),...,f(r)$排序,那么每存在一种不同的数则答案减1,那么$x$出现当且仅当$f(x ...

  5. 如何在C#中使用Google.Protobuf工具

    protobuf是一个语言无关.平台无关的序列化协议,由谷歌开源提供.再加上其高性能.存储占用更小等特点,在云原生的应用中越来越广泛. 在C#中主要有两种方法来使用protobuf协议,nuget包分 ...

  6. 《HelloGitHub》第 68 期

    兴趣是最好的老师,HelloGitHub 让你对编程感兴趣! 简介 HelloGitHub 分享 GitHub 上有趣.入门级的开源项目. https://github.com/521xueweiha ...

  7. No 'Access-Control-Allow-Origin' header: 跨域问题踩坑记录

    前言 前两周在服务器上部署一个系统时,遇到了跨域问题,这也不是第一次遇到跨域问题了,本来以为解决起来会很顺利,没想到解决过程中遇到了很多坑,所以觉得有必要写一篇博客记录一下这个坑. 问题产生原因 本来 ...

  8. P5599【XR-4】文本编辑器

    题目传送门. 题意简述:给定长度为 \(n\) 的文本串 \(a\) 和有 \(m\) 个单词的字典 \(s_i\).\(q\) 次操作,每次求出字典内所有单词在 \(a[l,r]\) 的出现次数,或 ...

  9. RSA,DSA,ECDSA,EdDSA和Ed25519的区别

    RSA,DSA,ECDSA,EdDSA和Ed25519的区别 用过ssh的朋友都知道,ssh key的类型有很多种,比如dsa.rsa. ecdsa.ed25519等,那这么多种类型,我们要如何选择呢 ...

  10. 【数据库】本地NR数据库如何按物种拆分?

    目录 1.准备本地数据库文件 1.1 NR库下载 1.2 Taxonomy数据库下载 2.按物种拆分NR库 2.1 第一步:获得Aceesson和分类物种的对应关系 2.2 第二步:获得分类物种的序列 ...