kruskal算法的c++实现
来源:互联网 发布:手机上开淘宝店怎么开 编辑:程序博客网 时间:2024/06/06 00:58
kruskal 算法的思想是将图中所有的顶点,都看作不同的连通分支,也就是他们每一个都是一个树。之后,从所有边中选权重最小的边,每次判断该边的两个顶点是否属于不同的连通分支,如果不属于,将此边加入,并修改两个顶点为一个连通分支 ; 若属于则继续选下一个权重最小的边进行上述判断,直到选中的边的个数等于N-1(N为顶点个数),算法结束,此时所有选中的边和所有的点为原图的最小生成树。
c++ 实现如下:
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <vector>
#include <unordered_map>
struct edges{
edges(int s ,int d , int w):source(s),dist(d),weight(w){}
int source;
int dist;
int weight;
};
bool comp(edges &a , edges &b){
return a.weight < b.weight;
}
int main(){
std::vector<edges> edge_array;
int graph[][6] = {
{0,1,4,0,0,0},
{1,0,1,0,4,0},
{4,1,0,3,0,0},
{0,0,3,0,4,5},
{0,4,0,4,0,0},
{0,0,0,5,0,0}
};
std::unordered_map<int,int> vTree;
for(int i =0 ; i < 6 ; i++){
vTree.insert(std::make_pair(i,i));
}
for(int i =0 ; i < 6 ; i++){
for(int j = i+1 ; j <6 ; j++){
if(graph[i][j] != 0){
edge_array.push_back(edges(i,j,graph[i][j]));
edge_array.push_back(edges(j,i,graph[i][j]));
}
}
}
std::sort(edge_array.begin(),edge_array.end(),comp);
//krusal algorithm begin
int weight_sum = 0;
int i = 0;
for(auto iter = edge_array.begin(); iter != edge_array.end() ; iter++){
if(i >= 5){
break;
}else{
if( vTree.find(iter->source)->second == vTree.find(iter->dist)->second ){
continue;
}else{
i++;
weight_sum += iter->weight;
if(iter->source < iter->dist){
vTree.find(iter->dist)->second = vTree.find(iter->source)->second;
}else{
vTree.find(iter->source)->second = vTree.find(iter->dist)->second;
}
std::cout << "edge: " << iter->source <<" -> " << iter->dist <<" = " << iter->weight << std::endl;
}
}
}
std::cout << "the MST result is : " << weight_sum << std::endl;
return 0;
}
阅读全文
0 0
- kruskal算法的实现
- Kruskal算法的实现
- kruskal算法的实现
- Kruskal算法C语言实现
- 配合Kruskal算法的二叉堆实现文件C语言
- Kruskal算法的C语言实现(并查集版)
- C语言实现图的Kruskal最小生成树算法
- Kruskal算法的JAVA实现
- kruskal算法的c++实现
- 最小生成树问题中Kruskal算法和Prim算法的C语言实现
- Kruskal算法的C语言程序
- Kruskal算法的设计与实现
- [数据结构] 图的Kruskal算法实现
- Kruskal算法的并查集实现
- 最小生成树Kruskal算法的实现
- 我的第一篇文章——Kruskal算法用C语言的实现!
- kruskal 算法实现
- kruskal 算法java实现
- 机房收费系统——测试计划
- Android 神经网络API 介绍
- Java并发编程札记-(四)JUC锁-09CyclicBarrier
- 配置环境变量没反应,无效果
- LInux 安装lepus监控系统
- kruskal算法的c++实现
- julia语言做数据预处理
- 推荐个学习python的网站
- 7.7、配置memtable阈值
- NYOJ488~素数环
- Android学习——自定义控件(1)
- 机器学习之Logistic回归
- Java内部类的继承关系和构造方法
- three.js光源的应用