news 2026/4/18 14:25:03

如何在C++的STL中巧妙运用std::find实现高效查找

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何在C++的STL中巧妙运用std::find实现高效查找

这篇文章展示如何在一个范围内搜索。这里坚持用标准版本的STL,并考虑由2个迭代器表示的范围。

STL可以被分成两部分:对已排序元素进行操作的部分以及对未排序元素进行操作的部分。

这种差异对搜索有两个影响:

  • 在已排序的集合中查找非常快,通常在对数时间内,而在未排序的集合中查找通常在线性时间内。

  • 在已排序范围上显示的所有方法都按照等价性(与<比较)来比较值,而在未排序范围上显示的方法则按照相等性(与==比较)来比较值。

这篇文章探讨以下3个问题:

  • 在那里吗?

  • 在哪里?

  • 应该在哪里(对于排序范围)?

二、在那里吗?

2.1、在未排序的元素上

这个问题可以用std::find来表示,并结合与范围末尾的比较:

代码语言:C++

自动换行

AI代码解释

vector<int> v = {...}; // v filled with values if (std::find(v.begin(), v.end(), 42) != v.end()) { ... }

当然,也可以用std::count来表示。

代码语言:C++

自动换行

AI代码解释

vector<int> v = {...}; // v filled with values if (std::count(v.begin(), v.end(), 42)) { ... }

返回值在if语句中隐式地转换为bool值:在这里,如果范围内至少有一个元素等于42,则计算结果为true

std::find相比,std::count方法有优点也有缺点。

std::count的优点:std::count避免与结束操作符进行比较。

std::count的缺点:

  • std::count遍历整个集合,而std::find在搜索到第一个与搜索值相等的元素时就返回。

  • std::find更好地表达了正在查找的内容。

因此,std::find更常用。

注意,要检查是否存在满足谓词而不等于值的元素,用std::count_ifstd::find_ifstd::find_if_not,这应该是必知的。

2.2、已排序元素

关于已排序元素,要用的算法是std::binary_search,直接返回一个bool值,表示搜索值是否在集合中具有等效元素。

代码语言:C++

自动换行

AI代码解释

std::set<int> numbers = {...}; // sorted elements bool is42InThere = std::binary_search(numbers.begin(), numbers.end(), 42);

三、在哪里?

更准确地说,希望获得指向搜索元素出现位置的迭代器。

3.1、在未排序的元素上

std::find。返回指向第一个和搜索值相等的元素的迭代器,如果没有找到该值,则返回指向集合末尾的迭代器。

代码语言:C++

自动换行

AI代码解释

std::vector<int> numbers = {...}; auto searchResult = std::find(numbers.begin(), numbers.end(), 42); if (searchResult != numbers.end()) { ... }

3.2、已排序元素

对于已排序的集合,STL没有像std::find那样简单的算法。但是std::find并不是真正为排序集合而设计的,因为它用的是相等而不是等价,并且它在线性时间而不是对数时间内操作。

对于给定的集合,如果确定现在和将来元素的类型的相等性与等价性是相同的,并且接受付出线性时间,std::find将是不错的选择,引起它是简单的接口。必须注意,std::find不是专门为排序范围进行操作而设计的。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 15:29:13

Creed —— 盾牌格挡

导入格挡动画可通过自己调整key骨架来简易的设置格挡动画&#xff1b;设置输入动作设置动画蓝图设置玩家角色蓝图格挡伤害减半

作者头像 李华
网站建设 2026/4/18 13:49:30

华为“不讲武德”,6500mAh+100W+鸿蒙OS6,首销跌至“新低价”

华为开发 在国内手机市场中&#xff0c;还是有不少人喜欢华为手机的&#xff0c;但是华为的Mate系列、Pura系列&#xff0c;价格入手门槛不低&#xff0c;近几年起步价还下探了很多&#xff0c;即便如此大家也觉得太贵了。同样都有高端机的小米、vivo以及OPPO&#xff0c;它们的…

作者头像 李华
网站建设 2026/4/18 4:31:30

电动汽车电池换电站选址与定容附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码及仿真咨询…

作者头像 李华
网站建设 2026/4/15 13:13:41

vue+uniapp+小程序springboot 畅玩安阳旅游网站平台的景点门票民宿预订-

文章目录 技术架构核心功能模块特色交互设计数据安全方案性能优化措施 主要技术与实现手段系统设计与实现的思路系统设计方法java类核心代码部分展示结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 技术架构 Vue.js作为前端框架&…

作者头像 李华