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

【数据结构与算法】最小生成树,Prim算法,Kruskal算法 详解

最小生成树的实际应用背景。

最节省经费的前提下,在n个城市之间建立通信联络网。

Kruskal算法(基于并查集)

void init() {for (int i = 1; i <= n; i++) {pre[i] = i;}
}ll root(ll a) {ll i = a;while (pre[i] != i) {i = pre[i];}return i = pre[i];
}bool merge(ll a, ll b) {ll ra = root(a);ll rb = root(b);if (ra == rb) {return 0;}pre[ra] = rb;return 1;
}ll kruskal() {sort(edge.begin(), edge.end());init();ll sum = 0;ll cnt = 0;for (const auto e : edge) {if (merge(e.u, e.v)) {sum += e.w;cnt++;}}return sum;
}

什么图适合用Prim算法求最小生成树,什么图适合用Kruskal算法求最小生成树。

  • Prim算法:归并顶点,与边数无关,适合于稠密图,即边的数量接近于节点数量的平方。Prim算法从一个节点开始,每次都添加一条连接已选节点和未选节点的最小边,因此它更适合于边的数量较多的情况。

  • Kruskal算法:归并边,适合于稀疏图,即边的数量远小于节点数量的平方。Kruskal算法每次都添加一条当前最小的边,只要这条边不会形成环,因此它更适合于边的数量较少的情况。

图示用Prim算法及Kruskal算法求最小生成树的过程。

  • Prim算法

  • Kruskal算法

http://www.lryc.cn/news/381894.html

相关文章:

  • 【启明智显产品分享】Model3工业级HMI芯片详解系列专题(三):安全、稳定、高防护
  • 【面试干货】Java中的四种引用类型:强引用、软引用、弱引用和虚引用
  • 对称/非对称加密
  • DDei在线设计器-API-DDeiSheet
  • 随想录 Day 69 并查集 107. 寻找存在的路径
  • Hi3861 OpenHarmony嵌入式应用入门--LiteOS Mutex
  • 使用STM32F103完成基于I2C协议的AHT20温湿度传感器的数据采集
  • Huffman树——AcWing 148. 合并果子
  • 05 Pytorch 数据读取 + 二分类模型
  • 数据仓库之Kappa架构
  • ReactNative进阶(二十八)Metro
  • python爬虫入门到精通路线
  • Java 笔记:常见正则使用
  • vue 2.0项目中使用tinymce富文本框遇到的问题
  • 【STM32+FPGA】先进算力+强安全+边缘AI,64位STM32MP2聚焦工业4.0应用
  • Git 和 TortoiseGit 安装和配置(图文详解)
  • OpenAI CTO谈GPT-5将达博士生智力水平;斯坦福评估排名前十两款来自中国
  • 焦化超低排平台组成部分
  • 鸿蒙 navigation路由跳转,页面struct 下的生命周期、onShow、onHidden等不会触发问题
  • BUUCTF [CISCN2019 华北赛区 Day2 Web1] Hack World
  • wsl2平台鸿蒙全仓docker编译环境快速创建方法
  • 商业秘密侵权
  • 高通安卓12-固件升级
  • 我的常见问题记录
  • Python 3.12 环境搭建(Windows版)
  • 植物大战僵尸杂交版如何手动修改金币钻石数
  • Salia PLCC cPH2 远程命令执行漏洞(CVE-2023-46359)
  • 路由表操作
  • 羊大师:拒绝心灵内耗:走向高效与平和
  • IOS Swift 从入门到精通:Swift 简介,Swift中变量和常量,Swift中字符串,Swift中整数和浮点数