0

0

c++如何对map中的元素按key或value排序 _c++ map元素排序方法

冰火之心

冰火之心

发布时间:2025-10-19 16:46:01

|

1075人浏览过

|

来源于php中文网

原创

std::map默认按key升序排序,基于红黑树实现;若需按value排序,可将元素复制到vector后用std::sort自定义比较逻辑,或使用multimap以value为key进行反向映射。

c++如何对map中的元素按key或value排序 _c++ map元素排序方法

在C++中,std::map 默认是根据 key 自动按升序排序的,这种排序是在插入元素时自动完成的,底层基于红黑树实现。因此,你不需要额外操作就能让 map 按 key 排序。但如果你想按 value 排序,或者需要自定义 key 的排序方式,则需要采取一些额外方法。

1. map 按 key 排序(默认行为)

std::map 默认按键(key)升序排列

#include 
#include 

int main() {
    std::map myMap = {{3, "three"}, {1, "one"}, {2, "two"}};

    for (const auto& pair : myMap) {
        std::cout << pair.first << ": " << pair.second << "\n";
    }
    // 输出:
    // 1: one
    // 2: two
    // 3: three
}

这是默认行为,无需干预。如果你希望 key 按降序排列,可以使用自定义比较函数:

std::map> descendingMap;
descendingMap[3] = "three";
descendingMap[1] = "one";
descendingMap[2] = "two";

// 输出为:3, 2, 1

2. map 按 value 排序

由于 map 不支持直接按 value 排序,你需要将元素复制到一个支持排序的容器(如 vector),然后使用 std::sort 并自定义比较逻辑。

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

步骤如下:

MiroThinker
MiroThinker

MiroMind团队推出的研究型开源智能体,专为深度研究与复杂工具使用场景设计

下载
  • 将 map 中的所有 pair 复制到 vector 中
  • 使用 std::sort 对 vector 排序
  • 排序依据设为 value
#include 
#include 
#include 
#include 

int main() {
    std::map myMap = {{"apple", 3}, {"banana", 1}, {"cherry", 2}};

    // 复制到 vector
    std::vector> vec(myMap.begin(), myMap.end());

    // 按 value 升序排序
    std::sort(vec.begin(), vec.end(),
        [](const auto& a, const auto& b) {
            return a.second < b.second;
        });

    // 输出结果
    for (const auto& pair : vec) {
        std::cout << pair.first << ": " << pair.second << "\n";
    }
    // 输出:
    // banana: 1
    // cherry: 2
    // apple: 3
}

若要按 value 降序,改为 a.second > b.second 即可。

3. 使用 multimap 实现 value 到 key 的反向映射(可选技巧)

如果你只关心排序输出,并且 value 可能重复,也可以考虑将数据插入 std::multimap,以 value 为 key,实现自动排序:

std::multimap sortedByValue;
for (const auto& pair : myMap) {
    sortedByValue.insert({pair.second, pair.first});
}

// 遍历即为按 value 排序的结果
for (const auto& pair : sortedByValue) {
    std::cout << pair.second << ": " << pair.first << "\n";
}

注意:multimap 允许重复 key,适合 value 相同的情况。

基本上就这些。map 本身只能按 key 排序,按 value 排序需借助 vector 或 multimap 等辅助结构。理解这一点后,处理起来并不复杂但容易忽略细节。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
sort排序函数用法
sort排序函数用法

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

395

2023.09.04

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

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

36

2025.11.16

golang map原理
golang map原理

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

61

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

42

2025.11.27

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

2

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

0

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

0

2026.01.29

热门下载

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

精品课程

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

共32课时 | 4.4万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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