C++ STL算法库怎么用?C++常用算法函数(sort, find)教程【效率提升】
技术百科
裘德小鎮的故事
发布时间:2026-01-01
浏览: 次 STL算法库是作用于容器的通用函数,不管理内存;sort需传入起始和结束迭代器,默认升序,支持greater()降序及lambda自定义规则。
STL算法库不是容器,而是作用于容器的一组通用函数——它们不管理内存,只操作已有数据,用对了能省下大量手写循环的功夫。
sort:排序要传迭代器,别传整个容器
sort需要两个迭代器(起点和终点),不是容器本身。默认升序,支持自定义比较逻辑。
- 基本用法:
sort(v.begin(), v.end());—— 对 vector 升序排列 - 降序:
sort(v.begin(), v.end(), greater()); - 自定义规则(比如按字符串长度):
sort(vs.begin(), vs.end(), [](const string& a, const string& b) { return a.size() - 注意:只对支持随机访问的容器(vector、deque、array)高效;list 要用
list::sort()成员函数
find / find_if:找值 or 找满足条件的元素
返回第一个匹配项的迭代器,没找到就返回 end(),务必检查!
-
find(v.begin(), v.end(), 42);—— 找值为 42 的元素 -
find_if(v.begin(), v.end(), [](int x) { return x % 2 == 0; });—— 找第一个偶数 - 用法统一:所有算法都靠迭代器范围工作,跟容器类型无关(vector、list、array 都行)
- 小技巧:配合
std::distance可转成下标(仅限支持随机访问的迭代器):auto it = find(v.begin(), v.end(), 5); int idx = distance(v.begin(), it);
其他高频实用算法
不用自己写 for 循环就能干很多事:
-
count / count_if:统计出
现次数,比如 count(v.begin(), v.end(), 0) -
accumulate(在中):求和、拼接、自定义折叠: accumulate(v.begin(), v.end(), 0)或accumulate(s.begin(), s.end(), string(""), plus()) -
transform:批量转换,比如把 vector 全部平方:transform(v.begin(), v.end(), v.begin(), [](int x) { return x*x; }); -
copy / copy_if:复制带条件,比手写 if+push_back 更清晰
基本上就这些。STL 算法不难,关键是记住“它只认迭代器范围”,别传容器,也别漏写头文件(、 等)。用熟之后,代码更短、意图更明、出错更少。
# 第一个
# 已有
# 自定义
# 要用
# 迭代
# 作用于
# 仅限
# auto
# go
# 循环
# c++
# String
# if
# int
# 字符串
# 排列
# 成员函数
# 算法
# for
# count
# Lambda
# const
# transform
# sort
# 只对
# copy
# Array
# 升序
# 降序
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Windows如何查看和管理已安装的字体?(字体文
- c++ std::atomic如何保证原子性 c+
- php订单日志怎么导出excel_php导出订单日
- Win10怎么卸载迅雷_Win10彻底卸载迅雷方法
- Win11时间不对怎么同步_Win11自动校准互联
- Python项目回滚策略_发布安全说明【指导】
- Drupal 中 HTML 链接被双重转义导致渲染
- Python函数接口文档化_自动化说明【指导】
- Windows10如何更改鼠标图标_Win10鼠标
- PythonWeb前后端整合项目教程_FastAP
- Win10如何更改用户账户控制_Windows10
- Win11怎么退出微软账户_切换Win11为本地账
- c# 在高并发场景下,委托和接口调用的性能对比
- Windows10系统怎么查看运行时间_Win10
- MAC怎么用连续互通相机里的“桌上视角”_MAC在
- c++怎么实现大文件的分块读写_c++ 文件指针s
- Win10怎样卸载TeamViewer_Win10
- Win11怎么设置组合键快捷方式_Windows1
- php怎么下载安装后设置错误日志_phpini l
- 本地php环境打开php文件直接下载_浏览器解析p
- Golang如何避免指针逃逸_Golang逃逸分析
- Windows10蓝屏SYSTEM_SERVICE
- Mac如何查看电池健康百分比_Mac系统信息电源检
- php做exe支持多线程吗_并发处理实现方式【详解
- Win10 BitLocker加密教程 Win10
- c++中如何使用虚函数实现多态_c++多态性实现原
- 如何高效识别并拦截拼接式恶意域名 spam
- C++如何使用std::optional?(处理可
- 获取 PHP 文件最后修改时间的正确方法
- c++的位运算怎么用 与、或、异或、移位操作详解【
- LINUX的SELinux是什么_详解LINUX强
- 如何在Mac上搭建Golang开发环境_使用Hom
- 如何快速验证Golang安装是否成功_运行go v
- C++如何获取CPU核心数?(std::threa
- Win10电脑怎么设置IP地址_Windows10
- PhpStorm怎么调试PHP代码_PhpStor
- Windows10怎么查看系统激活状态_Windo
- MySQL 中使用 IF 和 CASE 实现查询字
- Windows10如何更改系统字体大小_Win10
- Python迭代器生成器进阶教程_节省内存与懒加载
- Win11时间怎么同步到原子钟 Win11高精度时
- mac怎么安装adb_MAC配置Android A
- 如何有效拦截拼接式恶意域名的垃圾信息
- Python如何创建带属性的XML节点
- Windows10系统更新错误0x80070002
- Win11怎么开启移动热点_Windows11共享
- Python路径拼接规范_跨平台处理说明【指导】
- Windows 11无法安全删除U盘提示设备正在使
- 短链接还原php提示内存不足_调整PHP内存限制设
- Python函数接口稳定性_版本演进解析【指导】

现次数,比如
QQ客服