C++常用算法的简单总结

1、遍历算法

for_each(iterator beg, iterator end, func) :遍历容器

transform(iterator beg1, iterator end1, iterator beg2, _func): func可以直接搬运数据,也可以数据加减乘除之后搬运

2、查找算法

find(iterator beg, iterator end, 需要查找的数据) 查找元素

查找指定元素,找到返回指定元素的迭代器,找不到返回结束迭代器end()

find_if(iterator beg, iterator end, 查找条件<谓词>) 按条件查找元素

按值查找元素,找到返回指定元素的迭代器,找不到返回结束迭代器end()

count(iterator beg, iterator end, 需要统计的数据) 统计元素个数

count_if(iterator beg, iterator end, 统计条件<谓词>) 按条件统计元素个数

adjacent_find(iterator beg, iterator end) 查找相邻重复元素

只能找到相邻且重复的元素,如果重复但是不相邻,那么就不会找到

binary_search(iterator beg, iterator end, 需要查找的数据) 二分查找法

查找指定元素,查到返回true,否则返回true,并且仅仅针对有序序列

3、排序算法

sort(iterator beg, iterator end, _Pred) 对容器内元素进行排序

random_shuffle(iterator beg, iterator end) 指定范围内的元素随机调整次序

merge(iterator beg1, iterator end1,iterator beg2, iterator end2, 放在新容器的什么位置<v3.begin()>) 容器元素合并,并存储到另一个容器中

新容器要提前开辟空间:v3.resize();

注意:两个序列必须是有序数列,合并后仍旧是有序序列

例如:v1 = {1,2,3}, v2 = {2,3,4},合并之后:v3 = {1,2,2,3,3,4}

reverse(iterator beg, iterator end) 反转指定范围的元素

4、替换和交换算法

copy(iterator beg, iterator end, iterator dest目标容器的位置迭代器)

容器内指定范围的元素拷贝到另一个容器中

replace(iterator beg, iterator end, oldValue, newValue)

replace_if(iterator beg, iterator end, _Pred, newValue)

swap(容器1, 容器2)互换容器

相关推荐
散峰而望4 小时前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
CoderCodingNo4 小时前
【GESP】C++五级真题(贪心思想考点) luogu-B4071 [GESP202412 五级] 武器强化
开发语言·c++·算法
我有一些感想……4 小时前
An abstract way to solve Luogu P1001
c++·算法·ai·洛谷·mlp
智者知已应修善业5 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
..过云雨6 小时前
17-2.【Linux系统编程】线程同步详解 - 条件变量的理解及应用
linux·c++·人工智能·后端
量子炒饭大师6 小时前
Cyber骇客的逻辑节点美学 ——【初阶数据结构与算法】二叉树
c语言·数据结构·c++·链表·排序算法
fpcc6 小时前
C++编程实践—false_type和true_type的实践应用
c++
量子炒饭大师7 小时前
Cyber骇客神经塔尖协议 ——【初阶数据结构与算法】堆
c语言·数据结构·c++·二叉树·github·
王老师青少年编程8 小时前
2025年12月GESP(C++二级): 环保能量球
c++·算法·gesp·csp·信奥赛·二级·环保能量球
CoderCodingNo8 小时前
【GESP】C++五级真题(贪心思想考点) luogu-P11960 [GESP202503 五级] 平均分配
开发语言·c++·算法