std::map默认按key升序排列,可通过自定义比较器实现key降序;按value排序需将元素复制到vector等容器后使用std::sort。示例展示了key升序、key降序及value升序、降序的实现方法,其中value排序需额外处理。

在C++中,std::map 默认是按照 key 自动排序的,且默认为升序。这种排序是在插入元素时自动完成的,底层通常由红黑树实现。但有时我们需要根据 value 进行排序,这就需要额外操作。下面分别介绍按 key 排序和按 value 排序的方法。
1. std::map 按 key 排序(默认行为)
std::map 本身就以 key 为索引进行有序存储,默认按 key 升序排列。不需要额外操作。
示例代码:
#include
#include