#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
struct node
{
LL d;//储存距离
int u;//点的标号
bool operator < ( const node& b)const// & 表示的是引用,
{
return d > b.d; // 当定义优先队列的时候 这里的 > 代表的是进如有限队列的顺序,
// 也就是大的先进,所以出来的顺序是小的先出
}
};
// < 是被重载的运算符,即如果有两个结构体 a ,b 比较的时候必须是 a<b如果结果为真,就说明 a.d > b.d;如果为假,代表着a.d < b.d
这篇文章将的很好:https://www.cnblogs.com/Deribs4/p/5657746.html
有空的话看看什么是仿函数;
好像能仿写priority_queue<Node,vertor<Node>,greater(Node)>里面的greator函数
下面是重点摘抄:
2.3 对于自定义类型,则必须重载operator<或者重写仿函数。
2.3.1 重载operator<的例子:返回true时,说明左边形参的优先级低于右边形参
#include <iostr