greater<>() 、less<>()及运算符 < 重载在排序和堆中的使用

简略图

greater<>()(a, b) a > b 返回true,反之返回false

less<>()(a, b) a < b 返回true,反之返回false

在cmp中使用(正着理解)

规则返回true时a在前,反之b在前

在priority_queue中使用 (反着理解)

规则返回false时a在前,反之b在前

例子

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
struct g
{
    int a, b;
    bool operator<(const g &t) const
    {
        if (a != t.a)
            return a < t.a; // (结合priority_queue)形成关于a的最大堆 (直接sort)关于a从小到大
        return b > t.b;     // (结合priority_queue)这里形成的是 a的最大堆的基础上的 关于b的最小堆 (直接sort)在关于a从小到大的基础上 关于b从大到小
    }
};
int main()
{
    g t[3] = {{1, 2}, {1, 0}, {4, 8}};
    sort(t, t + 3);
    cout << t[0].a; // 1

    priority_queue<g> pq;
    pq.push({1, 2});
    pq.push({1, 0});
    pq.push({4, 8});
    cout << pq.top().a; // 4
}
相关推荐
zone77392 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub4 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub4 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub5 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙5 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
CoovallyAIHub8 小时前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
SparkX开源AI知识库9 小时前
手摸手带你安装OpenClaw并对接飞书
算法·架构
一语07169 小时前
3分钟搞懂深度学习AI:实操篇:卷积层
人工智能·算法
CoovallyAIHub1 天前
181小时视频丢给GPT-5,准确率只有15%——南大联合NVIDIA等五校发布多模态终身理解数据集
深度学习·算法·计算机视觉