首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >浅谈STL函数式、大<T>的用法

浅谈STL函数式、大<T>的用法
EN

Stack Overflow用户
提问于 2013-09-01 18:00:17
回答 1查看 236关注 0票数 2

当我写代码的时候,我被函数器的用法弄糊涂了。

如果我想对一个整数序列进行降序排序,我必须在sort的第三个参数中放入greater<int>,例如sort(v.begin(), v.end(), greater<int>());

但在处理priority_queue时,我必须将less<int>放在第三个参数中,以获得最大顶层堆,例如priority_queue< int, vector <int>, less<int> > heap;

所以我的问题是,为什么我们使用两个不同的函数器得到相同的升序关系?

有人能解释一下为什么会发生这种情况吗?最好使用STL实现中的源代码来让我更清楚。

为我糟糕的英语道歉。

非常感谢!

EN

回答 1

Stack Overflow用户

发布于 2013-09-01 18:12:03

默认的sort以小于升序排序,使用“-”作为比较元素的严格弱排序。默认的priority_queue保证顶部元素是最大的元素(即,它以小于降序的顺序“排序”),同样使用“-”作为比较元素的严格弱排序。如果你想颠倒语义,在这两种情况下,你可以使用“大于”而不是默认的“小于”,作为严格的弱排序。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18557282

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档