社区讨论

谁能帮我把dijkstra堆优化c++版的那个堆优化部分解释一下

学术版参与者 6已保存回复 11

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
11 条
当前快照
1 份
快照标识符
@mi7pblei
此快照首次捕获于
2025/11/21 01:24
4 个月前
此快照最后确认于
2025/11/21 01:50
4 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
const int MAXN=100010;
const int MAXM=200010;
const int INF=2147483647;
int n,m,s,x,y,z,num;
int dis[MAXN],head[MAXM];
bool vis[MAXN];
struct EDGE
{
	int to;
	int w;
	int nxt;
}ed[MAXM];
struct node
{
	int dis;
	int pos;
	bool operator <(const node &x)const
	{
		return x.dis<dis;
	}
};
void add(int x,int y,int z)
{
	num++;
	ed[num].to=y;
	ed[num].nxt=head[x];
	ed[num].w=z;
	head[x]=num;
}
void dijkstra(int s)
{
	priority_queue<node>q;
	for(int i=1;i<=n;i++) 
	{
		dis[i]=INF;
		vis[i]=true;
	}
	dis[s]=0;
	q.push((node){0,s});
	while(!q.empty())
	{
		node w=q.top();
		q.pop();
		int x=w.pos;
		if(vis[x])
		{
			vis[x]=false;
			for(int i=head[x];i;i=ed[i].nxt)
			{
				int y=ed[i].to;
				dis[y]=min(dis[y],dis[x]+ed[i].w);
				q.push((node){dis[y],y});
			}
		}
	}
}
int main()
{
	cin>>n>>m>>s;
	for(int i=0;i<m;++i)
	{
		cin>>x>>y>>z;
		add(x,y,z);
	}
	dijkstra(s);
	for(int i=1;i<=n;i++)
	{
		cout<<dis[i]<<" ";
	}
	return 0;
}

回复

11 条回复,欢迎继续交流。

正在加载回复...