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

acwing算法基础之搜索与图论--floyd算法

目录

  • 1 基础知识
  • 2 模板
  • 3 工程化

1 基础知识

floyd算法的时间复杂度为O(n^3),它用来解决多源最短路问题。它的原理是基于动态规划。

floyd算法的关键步骤:

  1. k从1到n。
  2. i从1到n。
  3. j从1到n,d[i][j] = min(d[i][j], d[i][k] + d[k][j])。
  4. 经过上述三重循环之后,数组d即是任意两个结点之间的最短距离。

2 模板

初始化:for (int i = 1; i <= n; i ++ )for (int j = 1; j <= n; j ++ )if (i == j) d[i][j] = 0;else d[i][j] = INF;// 算法结束后,d[a][b]表示a到b的最短距离
void floyd()
{for (int k = 1; k <= n; k ++ )for (int i = 1; i <= n; i ++ )for (int j = 1; j <= n; j ++ )d[i][j] = min(d[i][j], d[i][k] + d[k][j]);
}

3 工程化

题目1:求两两结点之间的最短距离。

#include <iostream>using namespace std;const int N = 210;
int n, m, q;
int d[N][N];int main() {cin >> n >> m >> q;for (int i = 1; i <= n; ++i) {for (int j = 1; j <= n; ++j) {if (i == j) d[i][j] = 0;else d[i][j] = 0x3f3f3f3f;}}int a, b, c;while (m--) {cin >> a >> b >> c;d[a][b] = min(d[a][b], c);}for (int k = 1; k <= n; ++k) {for (int i = 1; i <= n; ++i) {for (int j = 1; j <= n; ++j) {d[i][j] = min(d[i][j], d[i][k] + d[k][j]);}}}while (q--) {cin >> a >> b;if (d[a][b] > 0x3f3f3f3f / 2) cout << "impossible" << endl;else cout << d[a][b] << endl;}return 0;
}
http://www.lryc.cn/news/227074.html

相关文章:

  • Zabbix监控SSL证书有效期
  • Arduino OneButton按键处理库实现单击/双击/长按功能
  • day52 django的下载与安装
  • WebGL智慧城市软件项目
  • VMware重装后没有虚拟网卡
  • 软件安全基础
  • 探索项目管理软件的多重用途和益处
  • Arduino ESP8266使用AliyunIoTSDK.h连接阿里云物联网平台
  • 【车载开发系列】AutoSar中的CANTP
  • JUL日志
  • ZZ308 物联网应用与服务赛题第G套
  • 如何使用 vcpkg 编译Google-V8脚本引擎(ECMA/JavaScript)?
  • 系列二十二、idea Live Templates
  • 电脑本地安装宝塔/docker 安装宝塔
  • Java Lambda 表达式笔记
  • Flutter笔记:状态提升、控制器模式、GetX控制器和服务
  • 9.spark自适应查询-AQE之动态调整Join策略
  • CentOs7 NAT模式连接网络
  • linux安装git
  • thinkphp6 起步
  • 会员题-力扣408-有效单词缩写
  • spring-cloud-stream
  • 2.0 熟悉CheatEngine修改器
  • 微信小程序数据交互和缓存
  • kubernetes集群编排——k8s认证授权
  • rabbitmq下载安装教程
  • 数据分析实战 | SVM算法——病例自动诊断分析
  • Splunk Connect for Kafka – Connecting Apache Kafka with Splunk
  • Unity | Shader(着色器)和material(材质)的关系
  • Leetcode—69.x的平方根【简单】