社区讨论

64分求助

P1807最长路参与者 2已保存回复 1

讨论操作

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

当前回复
1 条
当前快照
1 份
快照标识符
@lz2bqhui
此快照首次捕获于
2024/07/26 14:31
2 年前
此快照最后确认于
2024/07/26 15:19
2 年前
查看原帖
CPP
#include<iostream>
#include<cstring>
using namespace std;
const int N=1510,M=50010;
int f[N],fir[N],nex[N],en[M],len[M],d[100*M],r;
bool b[N];
void rd(int v,int dis){
	f[v]=dis;
	if(!b[v]){
		d[++r]=v;
		b[v]=true;
	}
}
int main(){
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		int u,v,w;
		scanf("%d%d%d",&u,&v,&w);
		nex[i]=fir[u];
		fir[u]=i;
		en[i]=v;
		len[i]=w;
	}
	memset(f,-63,sizeof(f));
	int inf=f[0];
	int h=1;
	rd(1,0);
	while(h<=r){
		int u=d[h];
		int t=fir[u];
		while(t>0){
			int v=en[t];
			int L=f[u]+len[t];
			if(f[v]<L)rd(v,L);
			t=nex[t];
		}
		h++;
		b[u]=false;
	}
	if(f[n]==inf)cout<<-1<<endl;
	else cout<<f[n]<<endl;
}

回复

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

正在加载回复...