news 2026/4/21 8:48:53

如何在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/17 19:03:47

Python+Vue的基于大数据技术的电影推荐系统的设计与实现 Pycharm django flask

这里写目录标题项目介绍项目展示详细视频演示感兴趣的可以先收藏起来&#xff0c;还有大家在毕设选题&#xff08;免费咨询指导选题&#xff09;&#xff0c;项目以及论文编写等相关问题都可以给我留言咨询&#xff0c;希望帮助更多的人技术栈文章下方名片联系我即可~解决的思路…

作者头像 李华
网站建设 2026/4/17 0:48:07

Cassandra CQL 完全指南:大数据查询语言详解

Cassandra CQL 完全指南&#xff1a;大数据查询语言详解 关键词&#xff1a;Cassandra、CQL、大数据查询、分布式数据库、数据建模、NoSQL、高并发存储 摘要&#xff1a;本文将带你从零开始认识 Cassandra 的查询语言 CQL&#xff08;Cassandra Query Language&#xff09;。我…

作者头像 李华
网站建设 2026/4/17 1:27:58

单相动态电压恢复器补偿电压凹陷或过电压研究附Simulink仿真

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

作者头像 李华
网站建设 2026/4/17 23:22:17

Compose笔记(六十六)--ModalNavigationDrawer

这一节主要了解一下Compose中的ModalNavigationDrawer,在Jetpack Compose开发中&#xff0c;ModalNavigationDrawer是一个用于实现模态导航抽屉的核心组件&#xff0c;它允许用户通过侧滑手势或点击菜单图标触发一个覆盖在主内容之上的抽屉菜单&#xff0c;提供页面切换、功能导…

作者头像 李华
网站建设 2026/4/16 13:54:16

反激变换器与Buck - boost电路:电力变换的奇妙世界

反激变换器 - Buck-boost电路 在电力电子领域&#xff0c;反激变换器和Buck - boost电路就像两颗璀璨的明星&#xff0c;各自闪耀着独特的光芒&#xff0c;为我们实现各种电源转换需求立下汗马功劳。今天咱们就一起深入这两个神奇电路的世界&#xff0c;探索它们的奥秘。 Buc…

作者头像 李华