0

0

c++中如何对map按值value进行排序_c++ map排序技巧

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-03 16:54:08

|

667人浏览过

|

来源于php中文网

原创

std::map 无法按 value 排序,因其底层红黑树仅依据 key 自动排序;正确做法是将元素复制到 vector 后用 sort 或 stable_sort 按 second 字段排序,原 map 不变。

c++中如何对map按值value进行排序_c++ map排序技巧

map 本身不支持按 value 排序

这是最关键的前置判断:std::map 的底层是红黑树,它**只按 key 自动排序**,且插入/查找时间复杂度为 O(log n)。你无法通过修改比较器让它按 value 排序——因为 value 不参与树的结构维护,强行“重载”会破坏 map 的正确性。

把 map 转成 vector 再排序是最常用、最安全的做法

实际开发中,95% 的“按 value 排序 map”需求,本质是:拿到排序后的键值对序列用于遍历、打印或后续处理。这时应放弃原地排序幻想,转而提取数据再排序:

  • std::vector<:pair key value>> 存储所有元素(注意 const Key,因 map 的 key 是 const)
  • std::sort 配合 lambda 比较 second 字段
  • 若需稳定排序(相同 value 时保持原插入顺序),改用 std::stable_sort
  • 注意:排序后得到的是副本,原 map 不变
std::map m = {{"apple", 3}, {"banana", 1}, {"cherry", 3}};
std::vector> v(m.begin(), m.end());
std::sort(v.begin(), v.end(), [](const auto& a, const auto& b) {
    return a.second < b.second; // 升序:小 value 在前
});

遇到重复 value 时,排序结果可能不符合直觉

std::map 的 key 唯一,但 value 可以重复。排序后相同 value 的元素相对顺序取决于它们在原 map 中的 key 大小(因为 vector 初始化是按 map 的 key 顺序来的),不是插入顺序,也不是随机的:

Transfusion AI
Transfusion AI

一站式室内设计AI解决方案

下载
  • 例如 { {"x", 5}, {"a", 5} } 插入后,map 内部按 key 排为 {"a",5}, {"x",5},转 vector 后仍是这个顺序
  • 若想让相同 value 下按 key 升序排,lambda 可写成:[a.second == b.second ? a.first
  • 若想严格按原始插入顺序(C++17 起 map 不保证插入顺序),必须额外记录索引,不推荐

性能敏感场景要避免频繁转换 + 排序

如果需要反复按 value 查找 top-K 或动态更新后重排,map → vector → sort 的 O(n log n) 开销可能成为瓶颈:

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

  • 考虑改用 std::unordered_map + 手动维护一个 std::vectorstd::priority_queue(如用 std::priority_queue<:pair std::string>> 实现最大堆)
  • 若只查最小/最大 value,直接遍历 map 的 O(n) 比排序更轻量
  • 不要为了“看起来像 map”而封装一个假的“value-sorted-map”类——接口易误导,内部逻辑难维护
真正麻烦的地方在于:很多人试图给 std::map 换比较器去“骗过”编译器,结果发现 value 改变后整个结构就乱了。记住——map 的排序契约只绑定 key,别的都得自己动手。

相关专题

更多
string转int
string转int

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

314

2023.08.02

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

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

381

2023.09.04

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

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

520

2023.09.20

string转int
string转int

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

314

2023.08.02

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

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

524

2024.08.29

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

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

49

2025.08.29

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

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

190

2025.08.29

lambda表达式
lambda表达式

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

202

2023.09.15

漫画合集pdf网盘入口_漫画解说合集一口气看完
漫画合集pdf网盘入口_漫画解说合集一口气看完

精选高人气漫画合集PDF,一站式网盘入口直达!深度漫画解说整合,一口气看完经典与新作,剧情梳理清晰,省时省力,追漫党必看合集。

3

2026.01.04

热门下载

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

精品课程

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

共578课时 | 41.5万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

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

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