0

0

C++的std::algorithm头文件有哪些常用函数_C++算法库使用方法解析

尼克

尼克

发布时间:2025-11-17 11:46:35

|

842人浏览过

|

来源于php中文网

原创

std::algorithm头文件提供基于迭代器的通用算法,适用于vector等容器。1. 查找类:find、find_if查找元素,count、count_if统计满足条件的元素。2. 排序操作:sort排序,reverse反转,next_permutation生成下一排列。3. 修改算法:copy复制,fill填充,transform变换,replace替换。4. 集合操作:merge合并有序序列,set_union/intersection/difference求集合关系,unique去重。配合lambda与迭代器可提升编码效率。

c++的std::algorithm头文件有哪些常用函数_c++算法库使用方法解析

在C++中,std::algorithm 头文件提供了大量用于操作容器或普通数组的通用算法。这些函数不直接操作容器结构,而是通过迭代器对元素进行处理,因此适用于vector、list、array等支持迭代器的容器。下面介绍一些最常用且实用的函数及其使用方法。

查找类函数

这类函数用于在序列中搜索特定元素或满足条件的值。

  • std::find(begin, end, value):在区间 [begin, end) 中查找第一个等于 value 的元素,返回其迭代器,未找到则返回 end。
  • std::find_if(begin, end, pred):查找第一个满足谓词 pred 的元素,pred 是一个返回 bool 的函数或 lambda 表达式。
  • std::count(begin, end, value):统计 value 在区间中出现的次数。
  • std::count_if(begin, end, pred):统计满足条件 pred 的元素个数。

示例:

#include 
#include 
#include 

std::vector nums = {1, 3, 5, 7, 9, 5};

立即学习C++免费学习笔记(深入)”;

auto it = std::find(nums.begin(), nums.end(), 5); if (it != nums.end()) { std::cout << "找到元素,位置:" << it - nums.begin() << std::endl; }

int cnt = std::count(nums.begin(), nums.end(), 5); std::cout << "数字5出现了 " << cnt << " 次" << std::endl;

排序与排列操作

排序是日常开发中最常见的需求之一,algorithm 提供了高效且灵活的排序工具

  • std::sort(begin, end):对区间内元素升序排序,要求元素支持比较操作。
  • std::sort(begin, end, comp):使用自定义比较函数 comp 进行排序,例如降序可传入 std::greater() 或 lambda。
  • std::reverse(begin, end):反转区间中的元素顺序。
  • std::next_permutation(begin, end):生成下一个字典序排列,常用于全排列问题。
  • std::prev_permutation(begin, end):生成上一个字典序排列。

示例:

std::vector arr = {4, 2, 5, 1};

std::sort(arr.begin(), arr.end()); // 升序 // 结果:{1, 2, 4, 5}

std::sort(arr.begin(), arr.end(), [](int a, int b) { return a > b; }); // 降序

std::reverse(arr.begin(), arr.end()); // 反转

Copy Leaks
Copy Leaks

AI内容检测和分级,帮助创建和保护原创内容

下载

修改型算法

这些函数会修改原序列中的元素或将其复制到其他位置。

  • std::copy(begin, end, dest):将 [begin, end) 范围内的元素复制到以 dest 开始的位置,目标空间需已分配。
  • std::fill(begin, end, value):将区间所有元素设为 value。
  • std::transform(begin, end, result, op):对每个元素应用操作 op,并将结果写入 result 所指位置。
  • std::replace(begin, end, old_val, new_val):将区间中所有 old_val 替换为 new_val。

示例:

std::vector src = {1, 2, 3, 4};
std::vector dst(4);

std::copy(src.begin(), src.end(), dst.begin());

std::transform(src.begin(), src.end(), dst.begin(), [](int x) { return x * x; }); // dst 变为 {1, 4, 9, 16}

集合与合并操作

适用于已排序区间的高效操作。

  • std::merge(begin1, end1, begin2, end2, result):将两个有序区间合并为一个有序序列。
  • std::set_union / set_intersection / set_difference:求并集、交集、差集,同样要求输入有序。
  • std::unique(begin, end):去除连续重复元素(需先排序),返回去重后末尾迭代器,常配合 erase 使用。

示例:

std::vector a = {1, 2, 3}, b = {2, 3, 4};
std::vector res(6);
auto it = std::merge(a.begin(), a.end(), b.begin(), b.end(), res.begin());
res.resize(it - res.begin()); // 合并后调整大小

基本上就这些。熟练掌握这些函数可以大幅提升编码效率,减少手写循环带来的错误。注意多数算法要求数据范围有效,使用前确保容器非空或目标空间足够。结合 lambda 和迭代器,能写出简洁高效的 C++ 代码。

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.11.20

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

385

2023.09.04

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

385

2023.09.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

537

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

52

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

204

2023.09.15

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C++教程
C++教程

共115课时 | 12.3万人学习

手把手实现数据传输编码
手把手实现数据传输编码

共1课时 | 725人学习

c语言项目php解释器源码分析探索
c语言项目php解释器源码分析探索

共7课时 | 0.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号