ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

结构体优先队列的定义

2021-10-30 09:38:04  阅读:240  来源: 互联网

标签:priority 优先 定义 大根堆 队列 queue Que 小根堆 dis


前言

蒟蒻在定义优先队列时,经常忘记重载运算符之后优先队列该定义大根堆还是小根堆。

每次都得试一下 \(QwQ\)。

所以写一篇博客来记录一下,以后就不用试了。

正文

普通的优先队列有两种定义方法。

  1. 大根堆(默认):
priority_queue <int> q;
  1. 小根堆:
priority_queue <int, vector<int>, greater<int> > q;

但是这只是一个变量的情况下,当有多个变量怎么办呢?

有两个变量

如果只有两个变量的话,我们可以选择定义pair<first, second>

如果是 \(pair\) 类型的优先队列,那么它会按照 .first 比较并排序。

具体写法是这样的:

首先定义一下 \(pair\),方便后面写

typedef pair<int, int> P;
  1. 大根堆
priority_queue <P> q;
  1. 小根堆(同上面)
priority_queue <P, vector<P>, greater<P> > q;

有两个或多个变量

我们也可以选择结构体 + 重载运算符来实现。

具体来讲,就是重载运算符告诉程序要判断哪个变量。

这个如何定义小根堆呢?

我们以 \(dijkstra + 堆优化\) 为例:

struct Que{
    int x, dis;
    bool operator < (const Que &b) const{
        return dis > b.dis;//注意这里是大于号
    }
    // friend bool operator < (Que a, Que b){
    //     return a.dis > b.dis;
    // }
};

priority_queue <Que> q;

注意:不管是不是用 \(friend\) 这种写法,结构体里都是大于号。

大根堆的话自然把大于号改为小于号即可。

至于为什么,呵呵。

直观感觉就是 大于的大于 然后就变成 小于 了吧……

标签:priority,优先,定义,大根堆,队列,queue,Que,小根堆,dis
来源: https://www.cnblogs.com/xixike/p/15484285.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有