社区讨论
谁能帮我把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 条回复,欢迎继续交流。
正在加载回复...