当前位置: 首页 > news >正文

如何在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不是专门为排序范围进行操作而设计的。

http://www.jsqmd.com/news/188678/

相关文章:

  • 《不可被“框定”的理论:一场正在发生的生成性实验》研究
  • P14954 520 个人题解
  • 非遗万象图
  • 数据仓库与数据湖:大数据运营的存储架构对比
  • Docker一键搭建JmalCloud 个人网盘--自带博客!
  • 硅谷奇闻:英伟达创始人黄仁勋的家族传承与未来押注
  • Python+Vue的基于协同过滤算法的美食推荐系统 Pycharm django flask
  • vue基于Python基于大数据技术的共享单车数据分析与辅助管理系统 _Pycharm django flask
  • 学霸同款2025一键生成论文工具TOP9:本科生毕业论文必备测评
  • 深度测评!9个AI论文网站助你搞定毕业论文
  • 请求Cloudflare部署的pages资源的时候出现cors跨域问题
  • Python+Vue的基于大数据技术的电影推荐系统的设计与实现 Pycharm django flask
  • 学习笔记:PID算法入门笔记-电机控制-倒立摆
  • 吐血推荐!9款AI论文写作软件测评:研究生科研写作全攻略
  • Python+Vue的 增强可视化的广州IT招聘系统Pycharm django flask
  • Elasticsearch:在 Streams 中使用 ML 自动化 log 解析
  • 聚焦七大主战场丨华为孟晚舟:唯有迎难而上
  • 华为Pura 80系列有多香?到手可升级鸿蒙 6,至高还减1500元
  • phome_enewsfava 数据表字段解释(收藏表)
  • win10/win11安装Word、EXCEL、PPT、VISIO
  • 华为“不讲武德”,6500mAh+100W+鸿蒙OS6,首销跌至“新低价”
  • Creed —— 过场动画
  • 数据安全新防线:本地知识库
  • Creed —— 盾牌格挡
  • phome_enewsfavaclass 数据表字段解释(收藏分类表)
  • C语言2:分支循环
  • phome_enewsmembergroup 数据表字段解释(会员组表)
  • 点击劫持解析:揭秘看不见的界面攻击
  • 【A_Star三维路径规划】基于matlab A_Star算法无人机三维路径规划(含雷达威胁)【含Matlab源码 14816期】
  • phome_enewsmemberf 数据表字段解释(会员字段表)