优先队列比较函数

xiazdong 2010-12-25 06:35:55
priority_queue<Node*,vector<Node*>,cmp> myPq;
struct Node
{
int num;
Node*next;
int dist;
int prev;
Node(int n,Node*right=0):num(n),next(right){
}
Node()
{
dist=INT_MAX;
prev=0;
}
};

struct cmp
{
bool operator()(Node* a,Node* b)
{
if (a->dist<b->dist)
return true;
else return false;
}
};
目的是为了使得优先队列的结点都以dist的大小排序,但是为什么不行呢。。还是原来的顺序?
...全文
246 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
chlaws 2010-12-25
  • 打赏
  • 举报
回复
最好贴完整代码出来
qq120848369 2010-12-25
  • 打赏
  • 举报
回复
#include <iostream>
#include <queue>

using namespace std;

struct Node
{
Node(int n,int d,Node *right=0):num(n),dist(d),next(right) //你给num值,与dist有关?你哪里赋值dist了?
{

}

Node()
{
dist=INT_MAX;
prev=0;
}

int num;
int dist;
int prev;

Node*next;
};

struct cmp
{
bool operator() (const Node *a,const Node *b)
{
return a->dist < b->dist;
}
};


int main()
{
priority_queue<Node*,vector<Node*>,cmp> q;

q.push(new Node(1,4));
q.push(new Node(1,2));
q.push(new Node(1,6));

while(!q.empty())
{
cout<<q.top()->dist<<" ";
q.pop();
}

return 0;
}
無_1024 2010-12-25
  • 打赏
  • 举报
回复
估计是你的交换函数是按值传递 不是安引用传递
無_1024 2010-12-25
  • 打赏
  • 举报
回复
你只是返回了 ture 和false 又没有交换 当然是原来的结果啊
xiangchendub 2010-12-25
  • 打赏
  • 举报
回复
你的比较函数没有问题, 在其他的地方找问题吧。

64,687

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧