关于优先队列问题
struct road{
int x,y,count;//横纵坐标和花费的费用
/*friend bool operator<(road a,road b)//定义结构体的优先级比较方式 //这种形式是将比较运算符内置
{
return a.count>b.count;
}*/
}st,tp;
如果将比较运算符外置,该怎么写?我自己想的不知道对不对 请给位指教。。
data:image/s3,"s3://crabby-images/56314/563140ee7265469c03e1ef0a3e1cb1c3b0aa5ca8" alt=""
data:image/s3,"s3://crabby-images/56314/563140ee7265469c03e1ef0a3e1cb1c3b0aa5ca8" alt=""
data:image/s3,"s3://crabby-images/56314/563140ee7265469c03e1ef0a3e1cb1c3b0aa5ca8" alt=""
struct cmp
{
bool operator () (road a, road b) // 重载括号
{
return a.count >b.count; // 相当于less,大顶堆
}
};
priority_queue<road,vector<road>,cmp> q;