社区讨论

wa#12!

P3385【模板】负环参与者 2已保存回复 2

讨论操作

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

当前回复
2 条
当前快照
1 份
快照标识符
@lvz5xkk0
此快照首次捕获于
2024/05/09 19:26
2 年前
此快照最后确认于
2024/05/09 20:57
2 年前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
const int N=1e6;
int n,m;
int dist[N];
int vis[N];
int cnt[N];
struct node{
	int to;
	int w;
};
vector<node> g[N];
bool spfa(){
	memset(dist,0,sizeof dist);
	memset(cnt,0,sizeof cnt);
	queue<int>q;
	for(int i=1;i<=n;i++){
		q.push(i);
		vis[i]=1;
	}
	while(q.size()){
		int x=q.front();q.pop();
		vis[x]=0;
		for(int i=0;i<g[x].size();i++){
			int y=g[x][i].to,z=g[x][i].w;
			if(dist[y]>dist[x]+z){
				dist[y]=dist[x]+z;
				cnt[y]=cnt[x]+1;
				if(!vis[y]){
					q.push(y);
					vis[y]=1;
				}
				if(cnt[y]>n-1)return 1;
			}
		}
	}
	return 0;
}
int main(){
	int t;
	cin>>t;
	while(t--){
		cin>>n>>m;
		for(int i=1;i<=n;i++)g[i].clear();
		for(int i=1;i<=m;i++){
			int a,b,c;
			cin>>a>>b>>c;
			g[a].push_back({b,c});
			if(c>=0) g[b].push_back({a,c});
		}
		if(!spfa())cout<<"NO\n";
		else cout<<"YES\n";
	}
}

回复

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

正在加载回复...