1、此程序为c++程序

2、以下代码可实现手动输入,即去掉代码中的/*...*/注释符,并同时去掉赋值代码段

3、源代码

#include<iostream>

using namespace std;

#define MaxInt 32767

#define MVNum 100

typedef struct

{

char vexs[MVNum];

int arcs[MVNum][MVNum];

int vexnum, arcnum;

}AMGraph;

struct

{

char Head, Tail;

int lowcost;

}Edge[MVNum];

int Vexset[MVNum];

void CreateUDN(AMGraph &G);

void MiniSpanTree_Kruskal(AMGraph G);

int LocateVex(AMGraph G, char v);

int main()

{

AMGraph G;

char p = 'y';

while (p == 'y')

{

CreateUDN(G);

MiniSpanTree_Kruskal(G);

cout << "再次执行请输入:y,不执行请输入:n" << endl;

cin >> p;

}

system("pause");

return 0;

}

//生成无向图

void CreateUDN(AMGraph &G)

{

int i, j, k, w;

char v1, v2;

/*cout << "请输入顶点数和边数:";

cin >> G.vexnum >> G.arcnum;

cout << "请输入顶点:";

for (i = 0; i < G.vexnum; i++)

{

cin >> G.vexs[i];

}*/

G.vexnum = 6;

G.arcnum = 10;

G.vexs[0] = 'a';

G.vexs[1] = 'b';

G.vexs[2] = 'c';

G.vexs[3] = 'd';

G.vexs[4] = 'e';

G.vexs[5] = 'f';

//初始化

for (i = 0; i < G.vexnum; i++)

{

for (j = 0; j < G.vexnum; j++)

{

G.arcs[i][j] = MaxInt;

}

}

/*for (k = 0; k < G.arcnum; k++)

{

cout << "请输入边的起点、终点及权值:";

cin >> v1 >> v2 >> w;

Edge[k].Head = v1;

Edge[k].Tail = v2;

Edge[k].lowcost = w;

i = LocateVex(G, v1);

j = LocateVex(G, v2);

G.arcs[i][j] = w;

G.arcs[j][i] = G.arcs[i][j];

}*/

Edge[0].Head = 'a';

Edge[0].Tail = 'b';

Edge[0].lowcost = 6;

G.arcs[0][1] = G.arcs[1][0] = 6;

Edge[1].Head = 'a';

Edge[1].Tail = 'c';

Edge[1].lowcost = 1;

G.arcs[0][2] = G.arcs[2][0] = 1;

Edge[2].Head = 'a';

Edge[2].Tail = 'd';

Edge[2].lowcost = 5;

G.arcs[0][3] = G.arcs[3][0] = 5;

Edge[3].Head = 'b';

Edge[3].Tail = 'c';

Edge[3].lowcost = 5;

G.arcs[1][2] = G.arcs[2][1] = 5;

Edge[4].Head = 'c';

Edge[4].Tail = 'd';

Edge[4].lowcost = 5;

G.arcs[2][3] = G.arcs[3][2] = 6;

Edge[5].Head = 'b';

Edge[5].Tail = 'e';

Edge[5].lowcost = 3;

G.arcs[1][4] = G.arcs[4][1] = 3;

Edge[6].Head = 'c';

Edge[6].Tail = 'e';

Edge[6].lowcost = 6;

G.arcs[2][4] = G.arcs[4][2] = 6;

Edge[7].Head = 'c';

Edge[7].Tail = 'f';

Edge[7].lowcost = 4;

G.arcs[2][5] = G.arcs[5][2] = 4;

Edge[8].Head = 'd';

Edge[8].Tail = 'f';

Edge[8].lowcost = 2;

G.arcs[3][5] = G.arcs[5][3] = 2;

Edge[9].Head = 'e';

Edge[9].Tail = 'f';

Edge[9].lowcost = 6;

G.arcs[4][5] = G.arcs[5][4] = 6;

}

//构造最小生成树

void MiniSpanTree_Kruskal(AMGraph G)

{

int i, j, v1, v2, vs1, vs2;

for (i = 0; i < G.arcnum - 1; i++)

{

for (j = i + 1; j < G.arcnum; j++)

{

if (Edge[i].lowcost >Edge[j].lowcost)

{

Edge[MVNum] = Edge[i];

Edge[i] = Edge[j];

Edge[j] = Edge[MVNum];

}

}

}

for (i = 0; i < G.vexnum; i++)

{

Vexset[i] = i;

}

cout << "最小生成树:" << endl;

for (i = 0; i < G.arcnum; i++)

{

v1 = LocateVex(G, Edge[i].Head);

v2 = LocateVex(G, Edge[i].Tail);

vs1 = Vexset[v1];

vs2 = Vexset[v2];

if (vs1 != vs2)

{

cout << '(' << Edge[i].Head << ',' << Edge[i].Tail << ')' << endl;

for (j = 0; j < G.vexnum; j++)

{

if (Vexset[j] == vs2)

{

Vexset[j] = vs1;

}

}

}

}

}

//确定结点下标

int LocateVex(AMGraph G, char v)

{

int l, i;

for (l = 0, i = 0; i < G.arcnum; i++)

{

if (v == G.vexs[i])

{

l = i;

}

}

return l;

}

Kruskal(测试源代码)的更多相关文章

  1. 多啦爱梦~多啦A梦CSS3测试源代码

    先直接看图片,感觉一下!一直以来,我们都在说浏览器对CSS3支持度这个问题.可是,鉴于知识认识水平问题,又没几个人真正了解CSS3是什么东西,和它在网站显示上的重要性.现在好了,日本某位大神写了个CS ...

  2. JAVA语言课堂测试源代码及使用截图

    1源代码 第一部分 package 开学测试.java;class ScoreInformation {String stunumber;String name;double mathematicss ...

  3. Dijksktra(测试源代码)

    1.此程序为c++程序 2.以下代码可实现手动输入,即去掉代码中的/*...*/注释符,并同时去掉赋值代码段 3.源代码 #include<iostream> using namespac ...

  4. Huffman编码(测试源代码)

    1.此程序为c++程序 2.以下代码可实现手动输入,即去掉代码中的/*...*/注释符,并同时去掉赋值代码段 3.源代码 #include<iostream> using namespac ...

  5. Java开学测试源代码

    package sample; import java.io.IOException;import java.io.Serializable;import java.util.Scanner;impo ...

  6. Asp.net 面向接口可扩展框架之核心容器(含测试代码下载)

    新框架的容器部分终于调通了!容器实在太重要了,所以有用了一个名词叫“核心容器”. 容器为什么那么重要呢?这个有必要好好说道说道. 1.首先我们从框架名称面向接口编程说起,什么是面向接口编程?(这个度娘 ...

  7. Java学习-018-EXCEL 文件写入实例源代码

    众所周知,EXCEL 也是软件测试开发过程中,常用的数据文件导入导出时的类型文件之一,此文主要讲述如何通过 EXCEL 文件中 Sheet 的索引(index)或者 Sheet 名称获取文件中对应 S ...

  8. Java学习-013-文本文件读取实例源代码(两种数据返回格式)

    此文源码主要为应用 Java 读取文本文件内容实例的源代码.若有不足之处,敬请大神指正,不胜感激! 1.读取的文本文件内容以一维数组[LinkedList<String>]的形式返回,源代 ...

  9. Java学习-012-文件删除实例及源代码

    此文源码主要为应用 Java 创建文件的源代码.若有不足之处,敬请大神指正,不胜感激! 文件删除源代码如下: /** * @function 文件操作:删除文件.若文件存在且未被占用,则删除文件:若文 ...

随机推荐

  1. 基于C#在WPF中使用斑马打印机进行打印【转】

    原文链接:http://ju.outofmemory.cn/entry/132476 最近在项目中接手了一个比较有挑战性的模块——用斑马打印机将需要打印的内容打印出来.苦苦折腾了两天,总算有所收获,就 ...

  2. spark发行版笔记13

    本期概览: ReceiverTracker架构设计 消息循环系统 ReceiverTracker具体的实现 Spark Streaming作为Spark Core基础 架构之上的一个应用程序,其中的R ...

  3. ios项目中安装和使用CocoaPods

    CocoaPods是什么? http://code4app.com/article/cocoapods-install-usage http://blog.csdn.net/jjmm2009/arti ...

  4. hadoop输入分片计算(Map Task个数的确定)

    作业从JobClient端的submitJobInternal()方法提交作业的同时,调用InputFormat接口的getSplits()方法来创建split.默认是使用InputFormat的子类 ...

  5. MVB设备分类

    连接在MVB上的设备按性能可以分为5类 MVB上的设备应具备下面六个性能中的一个或多个. MVB设备的性能 性能 说明 分类 设备状态 设备被轮询时能够发送出其设备状态 1,2,3,4,5 过程数据 ...

  6. 查询数据库表大小sql

    SELECT a.name, b.rowsFROM sysobjects AS a INNER JOIN sysindexes AS b ON a.id = b.idWHERE (a.type = ' ...

  7. ASP通过ADODB读取Access数据库

    <% On Error Resume Next set conn=server.createobject("adodb.connection") mypath=server. ...

  8. POJ 3463 有向图求次短路的长度及其方法数

    题目大意: 希望求出走出最短路的方法总数,如果次短路只比最短路小1,那也是可取的 输出总的方法数 这里n个点,每个点有最短和次短两种长度 这里采取的是dijkstra的思想,相当于我们可以不断找到更新 ...

  9. 【mysql】关于循环插入数据 存储设计

    要求插入的数据有一定的规律 新建实例列表 CREATE TABLE users ( userId ) NOT NULL, userName ) NOT NULL, Serves ) NOT NULL, ...

  10. VScode调试Python

    第一步,确保装上了PYTHON扩展 然后打开文件夹(这个东西必须打开文件夹才能进行调试,不能打开一个文件就调试) 打开文件夹后,那里显示没有配置,这时需要你按下F5 弹出选择环境,点击Python 它 ...