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
}
相关推荐
smj2302_796826528 小时前
解决leetcode第3943题递增后的数对数量
数据结构·python·算法·leetcode
炽烈小老头9 小时前
【每天学习一点算法 2026/05/25】矩阵中的最长递增路径
学习·算法·矩阵
叁散10 小时前
实验报告:5G 仿真环境与基本链路模拟
算法
从负无穷开始的三次元代码生活10 小时前
算法零碎灵感点分享
算法
染指111011 小时前
9.LangChain框架(实现RAG)
数据库·人工智能·算法·机器学习·ai·大模型
大数据三康11 小时前
在spyder进行的遗传算法练习
开发语言·python·算法
Gene_202211 小时前
轮式底盘的微分平坦
算法
吴佳浩11 小时前
现代多模态大模型的核心基础:Unified Self-Attention
人工智能·算法·llm
小小编程路12 小时前
C++ 常用逻辑运算符
开发语言·c++·算法
Hali_Botebie12 小时前
两种子词分词算法BPE (Byte-Pair Encoding) 和Unigram 区别
人工智能·算法