floyed-多源汇聚最短路

  1. 时间复杂度O(n^3)
  2. 动态规划
  3. d[k][i][j] = min(d[k-1][i][j],d[k-1][i][k] + d[k-1][k][j])
  4. 可以简化为
  5. d[i][j] = min(d[i][j], d[i][k] + d[j][k]) //考虑经过k点时的最短路

代码

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cstdio>

using namespace std;

const int N = 210;

int g[N][N];

int n;

void floyed(){
    
    for(int k = 1; k <= n; k++){
        for(int i = 1; i <= n; i++){
            for(int j = 1; j <= n; j++){
                g[i][j] = min(g[i][j], g[i][k] + g[k][j]);
            }
        }
    }
    
}
int main(){
    int m,k;
    cin>>n>>m>>k;
    
    int x, y, z;
    
    //考虑重边和自环
    
    for(int i = 1; i <= n; i++){
        for(int j = 1; j <= n; j++){
            if(i == j){
                g[i][j] = 0; //去掉环 
            }else g[i][j] = 0x3f3f3f3f;
        }
    }
    
    for(int i = 0; i < m; i++){
        cin>>x>>y>>z;
        g[x][y] = min(g[x][y],z);
        
    }
    int a, b;
    int ans;
    
    floyed();
    for(int i = 0; i < k; i++){
        cin>>a>>b;
        if(g[a][b] > 0x3f3f3f3f/2){
            cout<<"impossible" << '\n';
        }else cout<< g[a][b]<< '\n';
        
    }
    
    
    
    return 0;
}
相关推荐
csdn_aspnet5 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
谙弆悕博士5 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
gaosushexiangji9 小时前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法
小王C语言10 小时前
【线程概念与控制】:线程封装
jvm·c++·算法
kyle~10 小时前
工程数学---点云配准卡布施(Kabsch)算法(求解最优旋转矩阵)
线性代数·算法·矩阵
张二娃同学11 小时前
03_变量常量与输入输出_printf与scanf详解
算法
江南十四行11 小时前
并发编程(一)
java·jvm·算法
z2005093012 小时前
今日算法(依旧二叉树)
算法·leetcode·职场和发展
Zxc_12 小时前
《遗传算法:从自然选择到Rastrigin函数优化,手写一个完整的进化求解器》
算法
阿Y加油吧12 小时前
两道经典动态规划题:乘积最大子数组 & 分割等和子集 复盘笔记
笔记·算法·动态规划