8.16日每日一题—最长路

_谦言万语 2022-08-16 20:58:30
加精
//floyd
#include <bits/stdc++.h>
#define MOD 1000000007
#define INF 0x3f3f3f3f
using namespace std;
typedef long long LL;
int n,m;
int f[1600][1600];
int main() {
	cin>>n>>m;
	for(int i=1; i<=n; i++)
		for(int j=1; j<=n; j++) {
			if(i==j) f[i][j]=0;
			else f[i][j]=-INF;
		}
	while(m--) {
		int u,v,w;
		cin>>u>>v>>w;
		f[u][v]=max(f[u][v],w);
	}
	for(int k=1; k<=n; k++)
		for(int i=1; i<=n; i++)
			for(int j=1; j<=n; j++)
				if(f[i][k]!=-INF && f[k][j]!=-INF)
					f[i][j]=max(f[i][j],f[i][k]+f[k][j]);
	if(f[1][n]==-INF) cout<<-1;
	else cout<<f[1][n];
	return 0;
}
//toposort
#include <bits/stdc++.h>
#define MOD 1000000007
#define INF 0x3f3f3f3f
using namespace std;
typedef long long LL;
int n,m;
int f[1600][1600],d[1600];
queue<int> q;

void bfs() {
	q.push(1);//起点
	d[1]=0;
	while(!q.empty()) {
		int h=q.front();
		q.pop();
		for(int i=1; i<=n; i++) {
			if(f[h][i] && d[i]<d[h]+f[h][i]) {
				d[i]=d[h]+f[h][i];
				q.push(i);
			}
		}
	}
}


int main() {
	cin>>n>>m;
	memset(d,-1,sizeof(d));
	for(int i=1; i<=m; i++) {
		int u,v,w;
		cin>>u>>v>>w;
		f[u][v]=max(f[u][v],w);
	}
	bfs();
	cout<<d[n];
	return 0;
}

 

...全文
71 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

51,713

社区成员

发帖
与我相关
我的任务
社区描述
和众多高校算法内卷分子,一起学习和交流算法那。浓郁的算法交流氛围,拒绝躺平,有效内卷。加入我们,私信我拉你入核心内卷群。
算法数据结构leetcode 个人社区
社区管理员
  • 执 梗
  • Dream-Y.ocean
  • ღCauchyོꦿ࿐
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

 刷题!

试试用AI创作助手写篇文章吧