第12周项目2-Kruskal算法的验证

来源:互联网 发布:mac上的邮箱怎么设置 编辑:程序博客网 时间:2024/05/20 19:46

以下图为例验证算法
这里写图片描述
main.cpp

#include <stdio.h>#include <malloc.h>#include "graph.h"#define MaxSize 100typedef struct{    int u;     //边的起始顶点    int v;     //边的终止顶点    int w;     //边的权值} Edge;void InsertSort(Edge E[],int n) //对E[0..n-1]按递增有序进行直接插入排序{    int i,j;    Edge temp;    for (i=1; i<n; i++)    {        temp=E[i];        j=i-1;              //从右向左在有序区E[0..i-1]中找E[i]的插入位置        while (j>=0 && temp.w<E[j].w)        {            E[j+1]=E[j];    //将关键字大于E[i].w的记录后移            j--;        }        E[j+1]=temp;        //在j+1处插入E[i]    }}void Kruskal(MGraph g){    int i,j,u1,v1,sn1,sn2,k;    int vset[MAXV];    Edge E[MaxSize];    //存放所有边    k=0;                //E数组的下标从0开始计    for (i=0; i<g.n; i++)   //由g产生的边集E        for (j=0; j<g.n; j++)            if (g.edges[i][j]!=0 && g.edges[i][j]!=INF)            {                E[k].u=i;                E[k].v=j;                E[k].w=g.edges[i][j];                k++;            }    InsertSort(E,g.e);      //采用直接插入排序对E数组按权值递增排序    for (i=0; i<g.n; i++)   //初始化辅助数组        vset[i]=i;    k=1;    //k表示当前构造生成树的第几条边,初值为1    j=0;    //E中边的下标,初值为0    while (k<g.n)       //生成的边数小于n时循环    {        u1=E[j].u;        v1=E[j].v;      //取一条边的头尾顶点        sn1=vset[u1];        sn2=vset[v1];   //分别得到两个顶点所属的集合编号        if (sn1!=sn2)   //两顶点属于不同的集合        {            printf("  (%d,%d):%d\n",u1,v1,E[j].w);            k++;                     //生成边数增1            for (i=0; i<g.n; i++)   //两个集合统一编号                if (vset[i]==sn2)   //集合编号为sn2的改为sn1                    vset[i]=sn1;        }        j++;               //扫描下一条边    }}int main(){    MGraph g;    int A[6][6]=    {        {0,6,1,5,INF,INF},        {6,0,5,INF,3,INF},        {1,5,0,5,6,4},        {5,INF,5,0,INF,2},        {INF,3,6,INF,0,6},        {INF,INF,4,2,6,0}    };    ArrayToMat(A[0], 6, g);    printf("最小生成树构成:\n");    Kruskal(g);    return 0;}

程序运行结果演示:
这里写图片描述
下面用测试图来测试
这里写图片描述
将测试的矩阵改成

int A[6][6]=    {        {0,10,INF,INF,19,21},        {10,0,5,6,INF,11},        {INF,5,0,6,INF,INF},        {INF,6,6,0,18,14},        {19,INF,INF,18,0,33},        {21,11,INF,14,33,0}    };

程序运行结果演示:
这里写图片描述

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 新买的木柜气味好重怎么办 淘宝店铺动态评分一直很低怎么办? 刚生下来的宝宝睡觉不吃奶怎么办 宝宝吐奶咳嗽了可能被呛到怎么办 床下面的液压支架支撑不了了怎么办 沙发的海绵垫坐着感觉太硬怎么办 修公路占地补偿盖房子房产证怎么办 哺乳期乳房有硬块挤不出来怎么办 老公投的公司倒闭了钱怎么办 小丑鱼老在缸上边游不下去怎么办 海缸养珊瑚又想养蝴蝶鱼怎么办 被几个月的小狗咬了怎么办 木本植物继代长出大量愈伤怎么办 钱兜树叶子发黄掉叶怎么办 手机qq群200人满了怎么办 支票被背书人的章盖浅了怎么办 没病装病的心理病患者怎么办 20多岁被骗40多万怎么办 一个学生上课爱捣乱班级课堂怎么办 军训的时候大姨妈来了怎么办 笔记本连接无线网说链接限制怎么办 12306密码和邮箱都忘了怎么办 烦恼都是自找的新书散页了怎么办 白色衣服被红色衣服染了怎么办 手机微信里面不能拍手功怎么办 肇事逃逸轻伤且对方不私了怎么办 数学差怎么办脑子不好啊数学学不老 手机号丢失微信密码丢失怎么办找回 悦借钱输入五次密码被锁怎么办 生源地助学贷款密码忘了怎么办 生源地助学贷款登录密码忘了怎么办 助学贷款支付宝密码忘了怎么办 微信密码忘记了手机号也换了怎么办 换手机号了微信密码忘记了怎么办 qq密码忘记了手机号也换了怎么办 一年只能修改一次昵称我能怎么办 华为手机的账号和密码丢失怎么办 华为手机的账号和密码丢失了怎么办 手机号被别人注册了微博怎么办 微博账号一天内多次解冻怎么办 露娜注册时邮箱填错了怎么办