实验九 最小生成树实验报告

时间:2025-04-30

一、实验目的

1.使学生熟悉最小生成树的意义和相应算法 2.掌握带权图的存储结构 二、实验环境

1、硬件:每个学生需配备计算机一台 2、软件: windows操作系统 + Turbo C 三、实验要求

1、能够独立完成带权图的存储和最小生成树的生成 四、代码

#include <stdio.h> #include <stdlib.h> #define MAX 100 #define MAXCOST 0x7fffffff int graph_hcy[MAX][MAX]; int Prim_hcy(int graph_hcy[][MAX], int n) { /* lowcost_hcy[i]记录以i为终点的边的最小权值,当lowcost[i]=0时表示终点i加入生成树 */ int lowcost_hcy[MAX]; /* mst_hcy[i]记录对应lowcost[i]的起点,当mst[i]=0时表示起点i加入生成树 */ int mst_hcy[MAX]; int i, j, min, minid, sum = 0; /* 默认选择1号节点加入生成树,从2号节点开始初始化 */ for (i = 2; i <= n; i++) { /* 最短距离初始化为其他节点到1号节点的距离 */ lowcost_hcy[i] = graph_hcy[1][i]; /* 标记所有节点的起点皆为默认的1号节点 */ mst_hcy[i] = 1; } /* 标记1号节点加入生成树 */ mst_hcy[1] = 0; /* n个节点至少需要n-1条边构成最小生成树 */ for (i = 2; i <= n; i++) { min = MAXCOST; minid = 0; /* 找满足条件的最小权值边的节点minid */ for (j = 2; j <= n; j++) { /* 边权值较小且不在生成树中 */ if (lowcost_hcy[j] < min && lowcost_hcy[j] != 0) { min = lowcost_hcy[j]; minid = j; } } /* 输出生成树边的信息:起点,终点,权值 */ printf("%c - %c : %d\n", mst_hcy[minid] + 'A' - 1, minid + 'A' - 1, min); /* 累加权值 */ sum += min; /* 标记节点minid加入生成树 */ lowcost_hcy[minid] = 0;

/* 更新当前节点minid到其他节点的权值 */ for (j = 2; j <= n; j++) { /* 发现更小的权值 */ if (graph_hcy[minid][j] < lowcost_hcy[j]) { /* 更新权值信息 */ lowcost_hcy[j] = graph_hcy[minid][j]; /* 更新最小权值边的起点 */ mst_hcy[j] = minid; } } } /* 返回最小权值和 */ return sum; } int main() { int i, j, k, m, n; int x, y, cost; char chx, chy; /* 读取节点和边的数目 */ scanf("%d%d", &m, &n); getchar(); /* 初始化图,所有节点间距离为无穷大 */ for (i = 1; i <= m; i++) { for (j = 1; j <= m; j++) {graph_hcy[i][j] = MAXCOST; } } /* 读取边信息 */ for (k = 0; k < n; k++) { scanf("%c %c %d", &chx, &chy, &cost); getchar(); i = chx - 'A' + 1; j = chy - 'A' + 1; graph_hcy[i][j] = cost; graph_hcy[j][i] = cost; } /* 求解最小生成树 */ cost = Prim_hcy(graph_hcy, m); /* 输出最小权值和 */ printf("Total:%d\n", cost); //system("pause"); return 0; }

实验九 最小生成树实验报告.doc 将本文的Word文档下载到电脑

    精彩图片

    热门精选

    大家正在看

    × 游客快捷下载通道(下载后可以自由复制和排版)

    限时特价:7 元/份 原价:20元

    支付方式:

    开通VIP包月会员 特价:29元/月

    注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
    微信:fanwen365 QQ:370150219