C++标准库algorithm
(1) 基本数学相关:
max(t1, t2)和min(t1, t2), 返回t1和t2中的较大、较小者。
max_element(b, e)和min_element(b, e), 返回两个迭代器所指定容器的最大、最小者。
accumulate(b, e, t, f[,f]), 对b与e之间的每个迭代器,进行f运算并赋值给t。
(2)比较:
equal(b, e, b2, [,p]), 返回一个布尔值,判断两个序列中的元素是否相等。
lexicographical_compare(b, e, b2, e2, [,p]), 返回一个布尔值,进行两个序列的比较,默认使用<关系符。
(3)copy与remove相关:
copy(b, e, d), 将由输出迭代器b和e界定的序列中的值复制到由迭代器d指定的目标容器中,返回一个值指向目标容器末后面的元素。
remove(b, e, t)和remove_if(b, e, p), 排列容器以使得在[b, e)中使谓词p为真或等于值t的元素位于这个域的尾部,返回一个迭代器,该迭代器指示了位于不被“删除”的元素之后的那个位置。可以与erase函数配合使用,如students.erase(remove_if(students.begin(), students.end(), fail_grade), students.end())得到及格的学生向量。
remove_copy(b, e, d, t) 和remove_copy(b, e, d, p), 与remove类似,不同的是,不改变[b,e), 将使谓词p为真或等关于值t的元素复制到由迭代器d指定的目标容器中。
replace(b, e, t1, t2)和replace_copy(b, e, d, t1, t2), 将容器[b, e)中的所有等于t1的元素替换为t2, replace_copy不改变源容器,将替换后的序列复制到目标容器并返回end()。
reverse(b, e)和reverse_copy(b, e, d), 将容器[b, e)中的所有元素倒序排列, reverse_copy不改变源容器,将替换后的序列复制到目标容器并返回end()。
unique(b, e)和unique_copy(b, e, d), 将容器[b, e)中的所有重复元素去除, unique_copy不改变源容器,将替换后的序列复制到目标容器并返回end()。
(4)查找与排序:
binary_search(b, e, t), 返回一个布尔值,表示值t是否在容器[b,e)中。
find(b, e, t)和find_if(b, e, p), 返回一个迭代器,指向一个序列中首次出现t值或满足p表达式的元素。
search(b, e, b2, e2, [,p]), 在[b,e)容器中查找子序列[b2,e2),返回第一个匹配的子序列首元素的正向迭代器。
sort(b, e, [,p])和stable_sort(b, e, [,p]),对容器[b, e)中的元素进行排序,stable_sort是稳定排序,对相等的各元素保持原来的顺序。
(5)其他:
fill(b, e, t), 将由迭代器b,e界定的容器填充值t,返回void类型。
partition(b, e, p)和stable_partition(b, e, p), 将容器[b, e)分为两部分,使谓词p为真的元素在前,返回第一个不满足谓词p的元素的迭代器。stable_partition使两部分的元素保持原来在容器中的先后顺序。
transform(b, e, [,b2], d, f]), f函数以b和e界定的序列和以b2指向的等长序列为参数,生成的结果序列储存到由输出迭代器d指定的目标容器中。
C++标准库algorithm的更多相关文章
- 【转】C++标准库和标准模板库
C++强大的功能来源于其丰富的类库及库函数资源.C++标准库的内容总共在50个标准头文件中定义.在C++开发中,要尽可能地利用标准库完成.这样做的直接好处包括:(1)成本:已经作为标准提供,何苦再花费 ...
- c++标准库和stl关系
C++标准库的所有头文件都没有扩展名.C++标准库的内容总共在50个标准头文件中定义,其中18个提供了C库的功能. <cname>形式的标准头文件[ <complex>例外]其 ...
- STL笔记(6)标准库:标准库中的排序算法
STL笔记(6)标准库:标准库中的排序算法 标准库:标准库中的排序算法The Standard Librarian: Sorting in the Standard Library Matthew A ...
- C++标准库概述 [转]
C++标准库的所有头文件都没有扩展名. C++标准库的内容总共在50个标准头文件中定义,其中18个提供了C库的功能.<cname>形式的标准头文件[<complex>例外]其内 ...
- C++标准库开发心得
最近放弃MFC,改用C++标准库开发产品.毕竟MFC用熟了,马上改用STL还不太习惯.下面列出下总结的改用STL遇到的问题和解决办法: 1.清除空格 remove_if(iterBegin, iter ...
- 什么是C++标准库?
C++中的标准程序库(简称标准库)是类库和函数的集合,其使用核心语言写成.标准程序库提供若干泛型容器.函数对象.泛型字符串和流(包含交互和文件I/O),支持部分语言特性和常用的函数,如开平方根.C++ ...
- [C/C++标准库]_[0基础]_[交集和补集]
场景: 1. 计算std::vector A和 std::vector B里的同样的元素, 用于保留不删除. 2. 计算std::vector A和 std::vector B里各自的补集, 用于删除 ...
- C++标准库和标准模板库
转自原文http://blog.csdn.net/sxhelijian/article/details/7552499 C++强大的功能来源于其丰富的类库及库函数资源.C++标准库的内容总共在50个标 ...
- Boost程序库完全开发指南——深入C++“准”标准库(第3版)
内容简介 · · · · · · Boost 是一个功能强大.构造精巧.跨平台.开源并且完全免费的C++程序库,有着“C++‘准’标准库”的美誉. Boost 由C++标准委员会部分成员所设立的Bo ...
随机推荐
- sessionStorage数组、对象的存储和读取
一个对象的demo如下: var obj = { name:"name", age:18, love:"美女" } sessionStorage.setItem ...
- ng-app&data-ng-app
来源stackoverflow 区别:在验证html5时,ng-app会抛出一个错误,而对带data-前缀的特性不会抛出.其它方面这两个属性一样.
- python使用stomp连接activemq
一.安装ActiveMQ服务 1. 当使用windows时,安装参考:https://blog.csdn.net/WuLex/article/details/78323811 启动:运行activem ...
- noj算法 迷宫问题 回溯法
描述: 给一个20×20的迷宫.起点坐标和终点坐标,问从起点是否能到达终点. 输入: 多个测例.输入的第一行是一个整数n,表示测例的个数.接下来是n个测例,每个测例占21行,第一行四个整数x1,y1, ...
- HTML基础-标签
html标签元素 html标签 在HTML静态页面中,每个网页具有唯一`<html></html>`,即`<html>`标签. html div标签 即网页中的盒子 ...
- from表单校验插件 validate 实例
$("#nextSubmit").click(function(){ $("#recovePasswordForm").submit(); }); $(&quo ...
- docker hub加速访问设置
前言:docker是国外的,虽然有个版本开源免费,但是其docker hub还是在国外,刚刚安装后,拉镜像就会发现,连接请求超时,中断服务,这是因为防火墙的问题,所以要将源指向国内的知名docker ...
- jdbc中的sql注入
- IntelliJ IDEA,酷炫插件系列,提高你的工作效率
今天介绍一下IDEA的一些炫酷的插件,IDEA强大的插件库,不仅能给我们带来一些开发的便捷,还能体现我们的与众不同. 1.插件的安装 打开setting文件选择Plugins选项 Ctrl + Alt ...
- fft,ntt
在被两题卡了常数之后,花了很久优化了自己的模板 现在的一般来说任意模数求逆1s跑3e5,exp跑1e5是没啥问题的(自己电脑,可能比luogu慢一倍) 当模数是$998244353,100453580 ...