100 pts wa on #2 求条
查看原帖
100 pts wa on #2 求条
991587
zhoujunchen楼主2025/7/20 12:29
#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,m,cnt[114],dis[114];
bool vis[1145];
struct edge{int v,w;};
vector<edge> g[114];
bool spfa(int s){
	queue<int> q;
	q.push(s);
	memset(dis,0x3f,sizeof(dis));
	dis[s]=0,vis[s]=1,cnt[s]++;
	while(q.size()){
		int u=q.front();
		q.pop();
		vis[u]=0;
		for(auto [v,w]:g[u]){
			if(dis[v]>dis[u]+w){
				dis[v]=dis[u]+w,vis[v]=1,cnt[v]++,q.push(v);
				if(cnt[v]>n)return 1;
			}
		}
	}
	return 0;
}
inline void man(){
	cin>>n>>m;
	for(int i=1,u,v,w;i<=m;i++){
		cin>>u>>v>>w;
		g[v].push_back({u-1,-w}),g[u-1].push_back({v,w});
	}
	for(int i=0;i<=n;i++)g[n+1].push_back({i,0});
	if(spfa(n+1))cout<<"false\n";
	else cout<<"true\n";
	
	
	
	for(int i=0;i<=n+1;i++)g[i].clear();
	memset(vis,0,sizeof vis);
	memset(cnt,0,sizeof cnt);
}
signed main(){
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	int t;
	cin>>t;
	while(t--)man();
	return 0;
}

2025/7/20 12:29
加载中...