当前位置: 首页 > news >正文

基础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;
}

 


http://www.mrgr.cn/news/2052.html

相关文章:

  • C#单例模式
  • 写一个githubDemo
  • Linux搭建环境:从零开始掌握基础操作(二)
  • 螺纹钢生产线中测径仪对基圆和负公差的测量和影响
  • ???牛客周赛55:虫洞操纵者
  • 【特殊文件---properties】
  • c语言网络编程
  • 欧拉远程桌面 安装tigervnc
  • 【Mybatis-plus】Mybatis-plus的踩坑日记之速查版
  • C语言---栈
  • UE网络架构和数据通信学习笔记
  • 企业高性能web服务器
  • 视频孪生技术在智慧水利(水务)场景中的典型应用展示
  • Java 细节特性
  • 前端工程化-05.Vue项目开发流程
  • 【HarmonyOS】鸿蒙应用蓝牙功能实现 (二)
  • 鸿蒙UIAbility组件概述(一)
  • Qt下使用QtPdfium处理PDF文档
  • 极速闪存启动:SD与SPI模式的智能初始化指南
  • 24年银行从业资格考试报名照规格要求