可爱妹子27pts 玄关求条
查看原帖
可爱妹子27pts 玄关求条
1122029
icebear233楼主2025/8/5 15:12
#include<bits/stdc++.h>
using namespace std;

struct node{
	int v,w;
};
vector<node> e[10555];
int cnt[10555],dis[10555];
bool vis[10555];
int n,m;
queue<int> q;
void add(int u,int v,int w){
	node t;
	t.v=v,t.w=w;
	e[u].push_back(t);
}
bool spfa(){
	dis[0]=0;
	vis[0]=1;
	q.push(0);
	while(q.size()){
		int t=q.front();
		q.pop();
		vis[t]=0;
		for(auto o:e[t]){
			int v=o.v;
			int w=o.w;
			if(dis[v]>dis[t]+w){
				cnt[v]=cnt[t]+1;
				dis[v]=dis[t]+w;
				if(cnt[v]==n+1){
					return false;
				}
				if(!vis[v]){
					q.push(v);
					vis[v]=1;
				}
			}
		}
		
	}
	return true;
}
int main(){
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		int u,v,w;
		cin>>u>>v>>w;
		add(u,v,w);
	}
	for(int i=1;i<=n;i++){
		add(0,i,0);
	}
	memset(dis,0x3f,sizeof(dis));
	if(spfa()){
		for(int i=1;i<=n;i++){
			cout<<dis[i]<<' ';
		}
	}
	else{
		cout<<"NO";
	}
	return 0;
}

(dis)); if(spfa()){ for(int i=1;i<=n;i++){ cout<<dis[i]<<' '; } } else{ cout<<"NO"; } return 0; }

2025/8/5 15:12
加载中...