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
}
相关推荐
真就死难3 小时前
完全日期(日期枚举问题)--- 数学性质题型
算法·日期枚举
不知道取啥耶3 小时前
C++ 滑动窗口
数据结构·c++·算法·leetcode
花间流风3 小时前
晏殊几何学讲义
算法·矩阵·几何学·情感分析
@心都3 小时前
机器学习数学基础:42.AMOS 结构方程模型(SEM)分析的系统流程
人工智能·算法·机器学习
北顾南栀倾寒6 小时前
[算法笔记]cin和getline的并用、如何区分两个数据对、C++中std::tuple类
笔记·算法
一只大侠7 小时前
牛客周赛A:84:JAVA
算法
豆豆酱8 小时前
Informer方法论详解
算法
槐月初叁8 小时前
多模态推荐系统指标总结
算法
迪小莫学AI8 小时前
LeetCode 2588: 统计美丽子数组数目
算法·leetcode·职场和发展
昂子的博客8 小时前
热门面试题第十天|Leetcode150. 逆波兰表达式求值 239. 滑动窗口最大值 347.前 K 个高频元素
算法