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

[图论]Kruskal

Kruskal

  • 本质:贪心,对边进行操作
  • 存储结构:边集数组。
  • 适用对象:可为负权图,可求最大生成树。
  • 核心思想:最短的边一定在最小生成树(MST)上,对最短的边进行贪心。
  • 算法流程:对全体边集 { E } \set{E} {E}由小到大排序。遍历所有边,每次添加使已选边集不成环的边,直到已选 V − 1 V-1 V1条边。可使用并查集判环,每次加边前先判断两点是否同属一个集合,每次加边时将两点合并到一个集合。
  • 复杂度: O ( E log ⁡ 2 E ) O(E\log_2E) O(Elog2E)

注:若无特殊说明,本文顶点与边编号均从0开始。

数据结构定义

using ll=long long;
ll n,m,s;//点数,边数,源点
struct edge{int u,v,w;
}e[m];
bool cmp(edge a,edge b){return a.w<b.w;
}
int s[n];
int Find(int x){if(s[x]!=x) s[x]=Find(s[x]);return s[x];
}
void init(){for(int i=0;i<n;i++) s[i]=i;
}

实现

int kruskal(){sort(e,e+m,cmp);init();int ans=0,cnt=0;for(int i=0;i<m;i++){if(cnt==n-1) break;int U=e[i].u,V=e[i].v,W=e[i].w;int u1=Find(U),u2=Find(V);if(u1==u2) continue;//成环,不选当前边else{ans+=W;s[u1]=u2;//合并到一个集合cnt++;}}if(cnt==n-1) return ans;return -1;
}

若求最大生成树,改为对边集 { E } \set{E} {E}由大到小排序即可。

相关文章:

  • Golang errors 包快速上手
  • 【安卓开发】【Android Studio】Menu(菜单栏)的使用及常见问题
  • Python解决“小D的abc字符变换”问题
  • 手机状态:UML 状态图(State Diagram)的解析与绘画
  • 天洑参加人工智能校企产学研及人才对接活动——走进南京大学人工智能学院
  • NO.96十六届蓝桥杯备战|图论基础-多源最短路|Floyd|Clear And Present Danger|灾后重建|无向图的最小环问题(C++)
  • Opencv函数及练习题
  • C# 如何比较两个List是否相等?
  • 【C++】list的模拟实现
  • android如何在生产环境中做到详实的日志收集而不影响性能?
  • Spark on K8s 在vivo大数据平台的混部实战
  • 如何用GEE下载选择的小区域范围Landsat影像
  • 【React】什么是 Hook
  • GitHub 趋势日报 (2025年04月16日)
  • 【APM】How to enable Trace to Logs on Grafana?
  • 超详细VMware虚拟机扩容磁盘容量-无坑版
  • 【JavaWeb后端开发01】Maven入门
  • 随手笔记-python-opencv 读取图像的顺序 与pytorch处理图像的顺序
  • win10下github libiec61850库编译调试sntp_example
  • Python PDF 转 Markdown 工具库对比与推荐
  • 中国驻美大使:远离故土的子弹库帛书正随民族复兴踏上归途
  • 新修订的《餐饮业促进和经营管理办法》公布,商务部解读
  • 网易一季度净利增长三成,丁磊:高度重视海外游戏市场
  • 上海市重大工程一季度开局良好,多项生态类项目按计划实施
  • 刘晓庆被实名举报涉嫌偷税漏税,税务部门启动调查
  • 回望星河深处,唤醒文物记忆——读《发现武王墩》