0

0

c++中如何使用std::partition_c++根据条件对容器分组方法【详解】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-21 17:45:52

|

623人浏览过

|

来源于php中文网

原创

std::partition 是标准库算法,用于原地二分重排容器元素:满足谓词的移至前段,不满足的移至后段,不保证组内顺序,时间复杂度 O(n),空间复杂度 O(1),返回指向第一不满足元素的迭代器。

c++中如何使用std::partition_c++根据条件对容器分组方法【详解】

std::partition 是什么,它能做什么

它把容器中满足条件的元素“全挪到前面”,不满足的“全挪到后面”,但不保证各自内部顺序。不是排序,也不创建新容器,是原地重排,时间复杂度 O(n),空间复杂度 O(1)。

关键点:它只做一次逻辑分组,返回一个迭代器,指向“满足条件部分”的末尾(即第一个不满足条件的元素位置)。

怎么写 predicate 才不会出错

predicate 必须是可调用对象,接受一个 const T&(或 T),返回 bool。常见错误是捕获局部变量时生命周期不对,或用了带副作用的 lambda 导致行为不可预测。

  • 避免在 lambda 中修改外部变量(比如 [&count] { ++count; return x > 0; }),std::partition 不保证调用次数和顺序
  • 不要返回未定义值:比如对 int* 解引用空指针再判断,或者除零
  • 如果要用成员变量,确保对象生命周期长于 partition 调用;推荐用值捕获或传入稳定参数
std::vector<int> v = {1, -2, 3, -4, 5};
auto it = std::partition(v.begin(), v.end(), [](int x) { return x > 0; });
// v 变成 {1, 3, 5, -2, -4}(顺序可能不同),it 指向 -2

std::partition 和 std::stable_partition 有什么实际区别

std::partition 不保序,快;std::stable_partition 保持各自组内原有相对顺序,但多耗内存(最坏 O(n) 额外空间)且稍慢。

Rose.ai
Rose.ai

一个云数据平台,帮助用户发现、可视化数据

下载

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

  • 需要保留正数原来的先后顺序?用 std::stable_partition
  • 只是快速分个类(比如把非空指针提前,方便后续批量处理),用 std::partition 就够了
  • std::liststd::partition 不能直接用(没有随机访问迭代器),但 std::list::partition 成员函数可用,且是稳定的

常见误用:以为它能按多个条件分三组或更多

它只能分两组:满足 predicate 的 + 不满足的。想实现“负数 / 零 / 正数”三分组,不能靠一次 std::partition 解决。

  • 错误做法:std::partition(..., [](int x){ return x != 0; }) 只能把零单独分出来,剩下正负混在一起
  • 正确思路:先用 std::partition 分出零,再对非零部分再 partition 一次;或改用 std::sort 配合自定义比较,或手写循环
  • 注意:多次 partition 会改变迭代器有效性——每次都要用新的 begin/end 范围,别拿上一轮的 it 直接当新范围起点用错位置
std::vector<int> v = {-1, 0, 2, 0, -3, 4};
auto zero_end = std::partition(v.begin(), v.end(), [](int x) { return x != 0; });
// 现在 [begin, zero_end) 是非零,[zero_end, end) 是零
auto pos_end = std::partition(v.begin(), zero_end, [](int x) { return x > 0; });
// [begin, pos_end) 是正数,[pos_end, zero_end) 是负数,[zero_end, end) 是零

真正要注意的是:predicate 的语义必须明确、无歧义,且在整个 partition 过程中保持纯函数特性。一旦 predicate 在不同调用中返回不一致结果(比如依赖全局时钟或 rand()),行为就未定义——这比编译报错更难排查。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

203

2023.11.20

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

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

409

2023.09.04

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

string转int
string转int

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

1031

2023.08.02

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

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

613

2024.08.29

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

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

334

2025.08.29

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

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

235

2025.08.29

lambda表达式
lambda表达式

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

215

2023.09.15

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共94课时 | 11.3万人学习

C 教程
C 教程

共75课时 | 5.4万人学习

C++教程
C++教程

共115课时 | 21.8万人学习

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

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