c++中常用的泛型算法
std中定义了很好几种顺序容器,它们自身也提供了一些操作,但是还有很多算法,容器本身没有提供。 而在algorithm头文件中,提供了许多算法,适用了大多数顺序容器。与c++11相比,很多函数在 c++17与c++20又改变了很多,下面内容基于c++11去简单介绍.
参考文献: https://en.cppreference.com或 https://zh.cppreference.com, 大家直接去这里看吧。。我就是拿的这里的!!!
介绍之前,首先说明两点:
- 关于泛型算法,必须明白一点:它们只会通过容器的迭代器来完成相关的操作,不会使用容器相关的任何操作。它意味着这些算法无论进行什么样的操作,容器的大小不会改变。
- 泛型算法相关的函数中,经常需要传入谓词(predicate)参数。谓词指的是可调用的对象,返回bool类型,例如:函数名、函数指针、lambda函数、重载了operator()的类对象等。包含一个参数的谓词称为一元谓词(unary predicate), 包含两个参数的谓词称为二元谓词(binary predicate)。
1. 只遍历容器而不修改容器元素的算法:
a. 判断给定的容器是否满足给定条件
all_of(iter1_, iter2_, unaryPredicate_) // 返回bool类型,如果容器内的所有元素, 对一元谓词为true,则返回true;
any_of(iter1_, iter2_, unaryPredicate_) // 返回bool类型,如果容器任何一个元素, 对一元谓词为true,则返回true;
none_of(iter1_, iter2_, unaryPredicate_) // 返回bool类型,如果容器内没有一个元素,对一元谓词为true,则返回true; (与all_of()正好相反)
b. 查找容器中满足条件的元素(如果不给定谓词参数,则会使用opretor==)
find(iter1_,iter2_, value) // 返回迭代器,它指向第一个等于value的元素。
find_if(iter1_,iter2_, unary_predicate_) // 返回迭代器,它指向第一个使一元谓词为true的元素。
find_if_not(iter1_, iter2_, unary_predicate_) // 返回迭代器,它指向第一个使一元谓词为false的元素。
find_first_of(iter1, iter2, iter11, iter22, binaryPredicate_) // 返回迭代器, 在[iter1,iter2)中查找在[iter11,iter22)出现的任意一个元素, 返回第一个满足条件的元素的迭代器。
find_end(iter1, iter2, iter11, iter22, binaryPredicate_) // 返回迭代器, 在 [iter1, iter2)中查找子序列[iter11, iter22), 返回满足条件的最后一个序列的起始元素。
fadjacent_find(iter1, iter2, binarayPredicate_) // 返回迭代器, 在[iter1, iter2)中查找相邻的元素满足条件的;
c. 查找容器中满足条件元素的数目
cout(iter1, iter2, value) // 返回满足条件的数目
cout_if(iter1, iter2, unaryPredidate_) // 返回使一元谓词为true的数目
d. 对容器内的每一个元素执行相同的操作
for_each(iter1_, iter2_, unaryFunction_) // 返回unaryFunction_, 该返回值对一般的函数或函数指针用处不大,对函数对象可能会有用;
// 作用:对指定范围内的所有元素依次执行一元函数操作.
for_each_n(iter1, n, unaryFunction_) // 返回迭代器,指向n个元素的下一个元素, 功能类似.(在c++17中开始有)
从这里到最后的截图图片来自:https://zh.cppreference.com/w/cpp/algorithm, 发现这样有现成的,真的赖得写了啊。
2. 修改序列的操作
3. 排序操作
4. 二分搜索操作
5.集合操作
6. 最大最小操作
另外,还有一些操作,不经常用,大家去推荐的网站看吧。
c++中常用的泛型算法的更多相关文章
- Java中常用的查找算法——顺序查找和二分查找
Java中常用的查找算法——顺序查找和二分查找 神话丿小王子的博客 一.顺序查找: a) 原理:顺序查找就是按顺序从头到尾依次往下查找,找到数据,则提前结束查找,找不到便一直查找下去,直到数据最后一位 ...
- 今天给大家分享一下js中常用的基础算法
今天给大家分享一下js中常用的基础算法,废话不多说,直接上代码: 1.两个数字调换顺序 ,b= function fun(a,b){ b = b - a ;// a = 2 ; b = 2 a = a ...
- C#中常用的排序算法的时间复杂度和空间复杂度
常用的排序算法的时间复杂度和空间复杂度 常用的排序算法的时间复杂度和空间复杂度 排序法 最差时间分析 平均时间复杂度 稳定度 空间复杂度 冒泡排序 O(n2) O(n2) 稳定 O(1) 快速排序 ...
- iOS标准库中常用数据结构和算法之查找
参数: key: [in] 要查找的元素.base:[in] 数组元素的首地址.nelp: [in/out] 数组的元素个数指针.width: [in] 数组中每个元素的尺寸.compar: [in] ...
- stl中常用的排序算法
#include"iostream" #include"vector" using namespace std; #include"string&qu ...
- 01java中常用的一些算法工具——map转xml和xml转map
借鉴博客:https://blog.csdn.net/Goodbye_Youth/article/details/80937862 他这篇写的不错,多层嵌套的map也能转成xml 这篇也不错:http ...
- C++ Primer 读书笔记:第11章 泛型算法
第11章 泛型算法 1.概述 泛型算法依赖于迭代器,而不是依赖容器,需要指定作用的区间,即[开始,结束),表示的区间,如上所示 此外还需要元素是可比的,如果元素本身是不可比的,那么可以自己定义比较函数 ...
- ACM 中常用的算法有哪些? 2014-08-21 21:15 40人阅读 评论(0) 收藏
ACM 中常用的算法有哪些?作者: 张俊Michael 网络上流传的答案有很多,估计提问者也曾经去网上搜过.所以根据自己微薄的经验提点看法. 我ACM初期是训练编码能力,以水题为主(就是没有任何算法, ...
- NAND Flash中常用的纠错方式(ECC算法)
Hanming,RS,BCH —— NAND Flash中常用的纠错方式 因为闪存中会有出错的可能,如果没有使用ECC模块,读出的数据和写入的数据会有不匹配的可能,也许一个文件中只有一两个bit不匹配 ...
随机推荐
- 20172327 2018-2019-1 《第一行代码Android》第二章学习总结
学号 2017-2018-2 <第一行代码Android>第二章学习总结 教材学习内容总结 - 活动是什么: 活动(Activity)是最容易吸引用户的地方,它是一种可以包含用户界面的组件 ...
- Android笔记--LinearLayout
LinearLayout 即线性布局,让子元素水平或垂直的排列在 layout中,子元素不会换行,当排到末尾时,剩下的组件将不会被显示出来. LinearLayout 常用的属性及方法: XML属性 ...
- 学习Struts--Chap01:了解Struts2
学习之前的一些话: 这是我系统学习Java知识这么久以来第一次接触web框架,很不幸的是刚开始学习它就听到很多人说这个框架现在已经过时了,很多企业现在开发项目几乎不会用这个框架了,就是有用这个框架的项 ...
- python动态构建类(类似声明)
对于类实例的动态构建,那是非常的简单.可要在代码中动态的构建类,然后该类还能够被使用,那得多么的强大呀. 在Python中,内建的__builtin__提供了一个type的方法,用该方法可以动态的构建 ...
- openstack之~glance安装部署
接着部署完keystone后,接着部署glance 第一:部署安装glance glance关于数据库的操作: [root@controller /]# mysql -u root -p Enter ...
- IO流(3)—字节流
IO体系: 抽象基类----节点流(文件流) InputStream--FileInputStream(字节流) OutputStream--FileOutputSteam(字节流) Reader - ...
- 问题7:JavaScript 常用正则示例
1. trim功能(清除字符串两端空格) String.prototype.trim = function() { return this.replace(/(^\s+)|(\s+$)/g, ''); ...
- js正则提取数字小数,提取中文,提取英文
var value="污染物:PM2.5"; //提取中文 console.log(value.replace(/[^\u4E00-\u9FA5]/g,'')); //提取英文 c ...
- mysql忘记密码时如何修改密码
1.首先关闭mysql服务 2.进入mysql安装目录,我的是在C:\Program Files\MySQL\MySQL Server 5.5\bin 3.dos命令行执行:mysqld -nt -- ...
- javascript umd esm slim
在CDN的连接中看到多个连接时如何选择? JavaScript 模块现状 UMD和ECMAScript模块 https://cdn.bootcss.com/popper.js/1.13.0/esm/p ...