您的位置:首页 > 教育 > 锐评 > 基础Floyd-Warshall算法

基础Floyd-Warshall算法

2025/8/21 14:15:24 来源:https://blog.csdn.net/2301_77869606/article/details/141369389  浏览:    关键词:基础Floyd-Warshall算法

小美想跑步:

F-小美想跑步_河南萌新联赛2024第(五)场:信息工程大学 (nowcoder.com)

1.解题思路:两点之间,直线最短,图论Floyd-Warshall算法 
2.dp[i][j][k]:点i到点j只经过0到k个点最短路径,降维说明:
发现dp[i][j][k]依赖于前面的k的值,例如dp[i][j][k-1],也就是说
如果我们已经计算了k-1个中介点,那么加上第k个中介点只能改善路径,或者保持不变,而不会更差。 
3.最后通过逐步引入中介点k来计算最优路径 

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int dp[1010][1010];//i到j的最短总路程
void fun(int n)
{for(int k=1;k<=n;k++){for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){dp[i][j]=min(dp[i][j],dp[i][k]+dp[k][j]);}}}
}
int main()
{int n,m;memset(dp,0x3f3f3f,sizeof(dp));cin>>n>>m;while(m--){int x,y,z;cin>>x>>y>>z;dp[x][y]=z;}fun(n);ll sum=0;for(int i=2;i<=n;i++){sum+=dp[1][i]+dp[i][1];}cout<<sum<<endl;return 0;
}

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com