社区讨论

迪杰斯特拉求助qwq

P3371【模板】单源最短路径(弱化版)参与者 2已保存回复 2

讨论操作

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

当前回复
2 条
当前快照
1 份
快照标识符
@loczrz8e
此快照首次捕获于
2023/10/30 22:25
2 年前
此快照最后确认于
2023/11/05 08:44
2 年前
查看原帖
CPP
#include <bits/stdc++.h>
using namespace std;

#define RE register
#define INF 2147483647
#define maxn 10010
#define ll long long

struct Edge{
	ll v,next,w;
}edge[500005];

priority_queue<pair<int,int> >q;

ll n,m,s,v[maxn],head[maxn],ans,x,y,z,cnt,d[maxn];

inline void fread(ll &x){
    x=0;
    int f=1;
    char ch=getchar();
    while(ch<'0'||ch>'9'){
        ch=getchar();
    }
    if(ch=='-')f=-1,ch=getchar();
    while(ch>='0'&&ch<='9'){
        x=(x<<1)+(x<<3)+(ch^48);
        ch=getchar();
    } 
    x*=f;
}

inline void add(int u,int v,int w){
	edge[++cnt].v=v;
	edge[cnt].w=w;
	edge[cnt].next=head[u];
	head[u]=cnt;
}

inline void dij(){
	for(RE int i=1;i<=n;i++)d[i]=INF;
	memset(v,0,sizeof(v));
	d[s]=0;
	q.push(make_pair(0,s));
	while(q.size()){
		int uu=q.top().second;
		q.pop();
		if(v[uu])continue;
		v[uu]=1;
		for(RE int i=head[uu];i;i=edge[i].next){
			int p=edge[i].v;
			int wi=edge[i].w;
			if(d[uu]>d[p]+wi){
				d[uu]=d[p]+wi;
				q.push(make_pair(-d[p],p));
			}
		}
	} 
}

int main(){
	fread(n);
	fread(m);
	fread(s);
	for(RE int i=1;i<=m;i++){
		fread(x);
		fread(y);
		fread(z);
		add(x,y,z); 
	}
	dij();
	for(RE int i=1;i<=n;i++){
		printf("%d ",d[i]);
	}
	return 0;
}

回复

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

正在加载回复...