全源最短路,为什么最后一个点WA了
查看原帖
全源最短路,为什么最后一个点WA了
344382
lmrttx楼主2021/1/3 18:29

不会有数组开小的问题吧,我都上了__int128了。

#include<bits/stdc++.h>
using namespace std;
#define inf 1e9
#define N 35000
#define M 65000
#define ll __int128
int head[N],vis[N],t[N],cnt,n,m;
ll h[N],dis[N],ans;
struct edge{int w,v,nxt;}e[M];
struct node{
	int dis,id;
	bool operator<(const node&a)const{return dis>a.dis;}
	node(int dis1,int id1){dis=dis1,id=id1;}
};
void add(int u,int v,int val){
	e[++cnt].v=v;e[cnt].w=val;
	e[cnt].nxt=head[u];head[u]=cnt;
}
queue<int> q;
bool spfa(int s){
	memset(h,63,sizeof(h));
	h[s]=0;vis[s]=1;q.push(s);
	while(!q.empty()){
		int u=q.front();q.pop();
		vis[u]=0;for(register int i=head[u];i;i=e[i].nxt){
			int v=e[i].v;if(h[v]>h[u]+e[i].w){
				h[v]=h[u]+e[i].w;if(!vis[v]){
					vis[v]=1;q.push(v);t[v]++;if(t[v]==n)return false;
				}
			}
		}
	}
	return true;
}
priority_queue<node> q1;
void dj(int s){
	for(register int i=1;i<=n;i++)dis[i]=inf;
	memset(vis,0,sizeof(vis));dis[s]=0;q1.push(node(0,s));
	while(!q1.empty()){
		int u=q1.top().id;q1.pop();
		if(vis[u])continue;vis[u]=1;for(int i=head[u];i;i=e[i].nxt){
			int v=e[i].v;if(dis[v]>dis[u]+e[i].w){
				dis[v]=dis[u]+e[i].w;if(!vis[v])q1.push(node(dis[v],v));
			}
		}
	}
	return;
}
int main(){
	scanf("%d%d",&n,&m);for(int i=1,u,v,w;i<=m;i++)scanf("%d%d%d",&u,&v,&w),add(u,v,w);
	for(int i=1;i<=n;i++)add(0,i,0);
	if(!spfa(0)){puts("-1");return 0;}
	for(int i=1;i<=n;i++)for(int j=head[i];j;j=e[j].nxt)
	e[j].w+=h[i]-h[e[j].v];
	for(register int i=1;i<=n;i++){
		dj(i);ans=0;for(int j=1;j<=n;j++){
			if(dis[j]==inf)ans+=j*inf;
			else ans+=j*(dis[j]+h[j]-h[i]);
		}
		printf("%lld\n",ans);
	}	return 0;
} 

求助,谢谢

2021/1/3 18:29
加载中...