最小生成树-kruskal
kruskal算法,没有进行算法复杂度分析
判断俩个结点是否在同一个树上使用了dfs,比较low的写法
输入数据
//第一行,结点数,结点数,边数
9 9 14
a b 4
b c 8
c d 7
a h 8
b h 11
h i 7
i c 2
i g 6
c f 4
d f 14
d e 9
f e 10
g h 1
g f 2
//============================================================================
// Name : kruskal.cpp
// Author : caicai
// Version :
//============================================================================ #include <iostream>
#include <stdio.h>
#include <memory.h>
using namespace std; struct Node
{
char s;
char e;
int w;
}; void printMap(int r, int a[][100])
{
for(int i = 0; i < r; i++)
{
for(int j = 0; j < r; j++)
{
printf("%-3d", a[i][j]);
}
cout << endl;
}
cout << endl;
}
/**
* 边根据权重从小到大排序
*/
void sortEdge(Node edges[], int total)
{
Node temp;
for(int i = 0; i < total; i++)
{
for(int j = 1; j < total; j++)
{
if(edges[j - 1].w > edges[j].w)
{
temp = edges[j - 1];
edges[j - 1] = edges[j];
edges[j] = temp;
}
}
}
}
void printEdges(Node edges[], int total)
{
for(int i = 0; i < total; i++)
cout << edges[i].s << " " << edges[i].e << " " << edges[i].w << endl;
}
void dfs(int a[][100], int r, int s, int e, int* ok, int vis[])
{
for(int i = 0; i < r; i++)
{
if(vis[i] || a[s][i] == 0)
{
//走过,不存在的路
continue;
}
if(i == e)
{
//可到
*ok = 0;
return;
}
vis[i] = 1;
//从当前结点出发,不需要回溯,如果当前结点到不了,从其他结点到当前结点同样是到不了
dfs(a, r, i, e, ok, vis);
}
}
void kruskal(int a[][100], int r, Node edges[], int et)
{
/**
* 图G n个结点,刚开始每一个结点都一个单独的结点,并没有与任何结点连接
* 将边按照权值从小到大排序
* 循环边集合,检查该边连接的俩个点,是否在同一个树上,如果是,不要,如果不是,加入到最小生成树中
* 怎么检查,a到b是否有一个条路
* 检查是否在同一个树中,dfs检查
*/
/*
*1初始化:生成的树为空,总权值为0
*2循环:每一次循环边,加入到数组a,数组a中包含n棵树,对于每一颗树,加入的边的权值最小,所以加入此边后形成的树的总权也是最小的
* 当俩棵树合并时,每棵的树的总权值也是最小的,所以相加后总权也是最小
*3终止:每一次加入的边是权值也是最小的,所以循环终止时,总权也是最小的
*/
for(int i = 0; i < et; i++)
{
char s = edges[i].s;
char e = edges[i].e;
int ok = 1;
int vis[100];
memset(vis, 0, sizeof(vis));
//检查耗时
dfs(a, r, s - 'a', e - 'a', &ok, vis);
if(ok)
{
//不在同一颗树中,当前的边加入到树中
a[s - 'a'][e - 'a'] = edges[i].w;
//无向图
a[e - 'a'][s - 'a'] = edges[i].w;
}
}
}
int main()
{
freopen("d:\\2.txt", "r", stdin);
int r;
int te;
cin >> r >> r >> te;
char s, e;
int w;
int a[100][100];
Node edges[100];
int et = 0;
while (te--)
{
cin >> s >> e >> w;
//cout << s << " " << e << " " << w << endl;
Node node;
node.s = s;
node.e = e;
node.w = w;
edges[et++] = node;
}
sortEdge(edges, et);
printEdges(edges, et);
kruskal(a, r, edges, et);
printMap(r, a);
return 0;
}
输出
g h 1
i c 2
g f 2
a b 4
c f 4
i g 6
c d 7
h i 7
b c 8
a h 8
d e 9
f e 10
b h 11
d f 14
0 4 0 0 0 0 0 0 0
4 0 8 0 0 0 0 0 0
0 8 0 7 0 4 0 0 2
0 0 7 0 9 0 0 0 0
0 0 0 9 0 0 0 0 0
0 0 4 0 0 0 2 0 0
0 0 0 0 0 2 0 1 0
0 0 0 0 0 0 1 0 0
0 0 2 0 0 0 0 0 0

最小生成树-kruskal的更多相关文章
- 模板——最小生成树kruskal算法+并查集数据结构
并查集:找祖先并更新,注意路径压缩,不然会时间复杂度巨大导致出错/超时 合并:(我的祖先是的你的祖先的父亲) 找父亲:(初始化祖先是自己的,自己就是祖先) 查询:(我们是不是同一祖先) 路径压缩:(每 ...
- 最小生成树——Kruskal与Prim算法
最小生成树——Kruskal与Prim算法 序: 首先: 啥是最小生成树??? 咳咳... 如图: 在一个有n个点的无向连通图中,选取n-1条边使得这个图变成一棵树.这就叫“生成树”.(如下图) 每个 ...
- 【转】最小生成树——Kruskal算法
[转]最小生成树--Kruskal算法 标签(空格分隔): 算法 本文是转载,原文在最小生成树-Prim算法和Kruskal算法,因为复试的时候只用到Kruskal算法即可,故这里不再涉及Prim算法 ...
- 最小生成树 kruskal算法 codevs 1638 修复公路
1638 修复公路 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description A地区在地震过后,连接所有村庄的公 ...
- 最小生成树——kruskal算法
kruskal和prim都是解决最小生成树问题,都是选取最小边,但kruskal是通过对所有边按从小到大的顺序排过一次序之后,配合并查集实现的.我们取出一条边,判断如果它的始点和终点属于同一棵树,那么 ...
- 贪心算法-最小生成树Kruskal算法和Prim算法
Kruskal算法: 不断地选择未被选中的边中权重最轻且不会形成环的一条. 简单的理解: 不停地循环,每一次都寻找两个顶点,这两个顶点不在同一个真子集里,且边上的权值最小. 把找到的这两个顶点联合起来 ...
- 最小生成树---Kruskal/Prime算法
1.Kruskal算法 图的存贮采用边集数组或邻接矩阵,权值相等的边在数组中排列次序可任意,边较多的不很实用,浪费时间,适合稀疏图. 方法:将图中边按其权值由小到大的次序顺序选取,若选边后不 ...
- 【BZOJ-2177】曼哈顿最小生成树 Kruskal + 树状数组
2177: 曼哈顿最小生成树 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 190 Solved: 77[Submit][Status][Discu ...
- 最小生成树Kruskal算法(邻接矩阵和邻接表)
最小生成树,克鲁斯卡尔算法. 算法简述: 将每个顶点看成一个图. 在所有图中找权值最小的边.将这条边的两个图连成一个图, 重复上一步.直到只剩一个图. 注:将abcdef每个顶点看成一个图.将最小权值 ...
- 最小生成树 kruskal hdu 5723 Abandoned country
题目链接:hdu 5723 Abandoned country 题目大意:N个点,M条边:先构成一棵最小生成树,然后这个最小生成树上求任意两点之间的路径长度和,并求期望 /************** ...
随机推荐
- STM32 外部中断
1)STM32一般有19 个外部中断为: 线 0~15:对应外部 IO 口的输入中断.线 16:连接到 PVD 输出. 线 17:连接到 RTC 闹钟事件. 线 18:连接到 USB 唤醒事件. 2) ...
- 利用Fierce2查询子域名
http://pnig0s1992.blog.51cto.com/393390/368428 安装方法引用Mickey的: 1.Mickey@pentestbox:/pentest/enumerati ...
- BZOJ3551: [ONTAK2010]Peaks加强版【Kruskal重构树】【主席树】
重要的事情说三遍 不保证图联通 不保证图联通 不保证图联通 那些和我一样认为重构树是点数的童鞋是要GG Description [题目描述]同3545 Input 第一行三个数N,M,Q. 第二行N个 ...
- .NET 中小心嵌套等待的 Task,它可能会耗尽你线程池的现有资源,出现类似死锁的情况
一个简单的 Task 不会消耗多少时间,但如果你不合适地将 Task 转为同步等待,那么也可能很快耗尽线程池的所有资源,出现类似死锁的情况. 本文将以一个最简单的例子说明如何出现以及避免这样的问题. ...
- JQuery判断form表单是否为空
功能:通过jquery判断form表单中是否有内容还未填写,如果有未填写的,则阻止提交 $(function () { $('form').bind('submit',function () { / ...
- C# NPOI导出Excel和EPPlus导出Excel
转自:http://www.cnblogs.com/tanpeng/p/6155749.html 系统中经常会使用导出Excel的功能.之前使用的是NPOI,但是导出数据行数多就报内存溢出. 最近看到 ...
- JSONObject JSONArray json字符串 HashMap ArryList 在java开发中用到的数据结构
1.JSONObject 长成这样的: { "key1":value1, "key2":value2, "key3":value3} ...
- oracel SQL多表查询优化
SQL优化 1.执行路径:ORACLE的这个功能大大地提高了SQL的执行性能并节省了内存的使用:我们发现,单表数据的统计比多表统计的速度完全是两个概念.单表统计可能只要0.02秒,但是2张表联合统计就 ...
- Revit API 加载族并生成实例图元
在Revit API中加载族可以使用Doc.LoadFamily方法,传入要加载的族文件路径名,但是这种方式有一种缺点,就是如果族文件在当前工程中没有加载的话则返回成功,如果已经加载过,则返回失败,也 ...
- wxWidgets:给窗口添加工具条
请先看上一篇<wxWidgets入门>. 修改MyFrame.h: #ifndef MYFRAME_H #define MYFRAME_H #include <wx/wxprec.h ...