90分求助
查看原帖
90分求助
152338
Accelerator_5楼主2022/12/8 13:31

RT,只有90分,第三个点始终过不了……

#include<iostream>
#include<cmath>
#include<iomanip>
#include<cstdio>
#include<string>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
long long int dis1[100005],n,m,h[100005],cnt=1;
long long int cntn[100005];
bool vis[100005];
struct Edge{
	long long int to;
	long long int nxt;
	long long int w;
}edge[100005];
queue<long long int> q;
void add(long long int u,long long int v,long long int w){
	edge[cnt].to=v;
	edge[cnt].nxt=h[u];
	edge[cnt].w=w;
	h[u]=cnt++;
}
bool is;
long long int pre[100005],fr[100005];
void spfa(int s){
	memset(dis1,0x3f,sizeof(dis1));
	dis1[s]=0;
	vis[s]=1; 
	q.push(s);
	while(!q.empty()){
		int t=q.front();
		q.pop();
		vis[t]=0;
		for(int i=h[t];i;i=edge[i].nxt){
			int j=edge[i].to;
			if(dis1[j]>dis1[t]+edge[i].w){
				dis1[j]=dis1[t]+edge[i].w;
				pre[j]=i;
				fr[j]=t;
				if(!vis[j]){
					vis[j]=1;
					q.push(j);
				}
			}
		}
	}
}
int main(){
	cin>>n>>m;
	for(long long int i=1;i<=m;i++){
		long long int u,v,w;
		cin>>u>>v>>w;
		add(u,v,w);
		add(v,u,w);
	}
	spfa(1);
	long long int f=dis1[n];
	long long int num[100005],s=0;
	long long int now=n;
	while(now!=1){
		num[++s]=pre[now];
		now=fr[now];
	}
	long long int ans=0;
	for(long long int i=1;i<=s;i++){
		edge[num[i]].w*=2;
		edge[num[i]^1].w*=2;
		spfa(1);
		ans=max(ans,dis1[n]);
		edge[num[i]].w/=2;
		edge[num[i]^1].w/=2;
	}
	cout<<ans-f;
	return 0;
}
2022/12/8 13:31
加载中...