STL set、map、priority_queue默认排序

本文深入探讨了C++中的三种容器:set、map和priority_queue的排序规则。set和map默认按升序排列元素,而通过指定比较函数可以改变排序方向。priority_queue默认实现为大根堆,即队头元素最大,但同样可以通过定制比较函数创建小根堆。了解这些容器的排序机制对于高效使用C++编程至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

set

set<T> s;//默认升序,相当于 set<int,less<T>>。
set<T, less<T>> s; //该容器是按升序方式排列元素。
set<T, greater<T>> s;  //该容器是按降序方式排列元素。

map

map<T1, T2> m;//默认按键的升序方式排列元素,相当于 map<T1, T2, less<T1>> m
map<T1, T2, less<T1>> m; //该容器是按键的升序方式排列元素。
map<T1, T2, greater<T1>> m;  //该容器是按键的降序方式排列元素。

priority_queue

priority_queue<T> p; //默认降序,大根堆,队头元素最大
priority_queue<T, vector<T>, less<T>> p; //相当于默认
priority_queue<T, vector<T>, greater<T>> p; //升序,最小值优先级队列,小根堆
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值