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 ...
随机推荐
- window开发环境常用操作
1. 启动redis命令 redis-server redis.windows.conf 如果法正常启用,出现如下问题 windows下第一次通过以下命令启动redis (*:此处整理转载自:http ...
- 023_supervisorctl管理服务注意事项
一. (1)问题 我在线上使用supervisorctl管理服务时遇到程序文件更新了,但是下次supervisorctl执行的时候并没有更新, 原因是supervisor更新后必须重新读取加载文件才行 ...
- Node中包的加载机制
1.Node原生提供的核心模块:http.fs.os.path.url.querystring,Node在加载核心模块时,不需要传入路径,因为Node.js已经将核心模块的文件代码编译到了二进制的 ...
- js检测数据类型四种办法
面试题中经常会考js数据类型检测,今天我来分享一下js中常用的四种方法判断数据类型,欢迎指点更正. 废话不多说,直入正题. 1.typeof console.log(typeof "&quo ...
- 论文阅读笔记四十五:Region Proposal by Guided Anchoring(CVPR2019)
论文原址:https://arxiv.org/abs/1901.03278 github:code will be available 摘要 区域anchor是现阶段目标检测方法的重要基石.大多数好的 ...
- 办公用品管理系统VB——库存数量导出EXCEL,SaveEXCEL
办公用品管理系统VB——库存数量导出EXCEL,SaveEXCEL 总体来说,VB的EXCEL导出效率还是蛮低的,就是一个小型化的办公用品管理软件,不再优化了. 时间紧迫,就没有从头到尾的用C#编写, ...
- 常用的js正则验证整理
一.校验数字的js正则表达式 1 数字:^[0-9]*$ 2 n位的数字:^\d{n}$ 3 至少n位的数字:^\d{n,}$ 4 m-n位的数字:^\d{m,n}$ 5 零和非零开头的数字:^(0| ...
- String Formatting in C#
原文地址 http://blog.stevex.net/string-formatting-in-csharp/ When I started working with the .NET framew ...
- MERGE INTO无法更新ON中的字段解决办法
可以将on里的条件放到update 之后的where条件里 MERGE INTO xshtest.WEB_USER_VIP T1 USING ( select 53254624 enterpriseI ...
- Imcash:比特币减半 四年机遇你能否抓住?
减半到底是什么? 2010来,比特币已有4次下跌幅度达70%或更高. 2012年的11月份比特币减半,诞生了一次上涨10倍有余的超级牛市. 2016年7月,历史又是如此的相似,比特币产量又迎来了减半, ...