实验九 最小生成树实验报告
一、实验目的
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; }
相关推荐:
- [文秘资料]班长职务辞职报告
- [文秘资料]完美的辞职报告
- [文秘资料]经典的员工辞职报告
- [文秘资料]医院口腔医生辞职报告
- [文秘资料]总经理辞职报告范文四篇
- [文秘资料]超市职员个人辞职报告
- [文秘资料]村妇联主任的辞职报告
- [文秘资料]辞职报告书格式
- [文秘资料]酒店辞职报告简单范文
- [文秘资料]联通的辞职报告
- [文秘资料]2017最新私企员工辞职报告范文
- [文秘资料]2019年度医院基层党组织书记抓党建述职
- [文秘资料]工作时间长辞职报告
- [文秘资料]辞职报告怎么写出来
- [文秘资料]个人能力原因辞职报告
- [文秘资料]网络工程师辞职报告
- [文秘资料]项目部辞职报告
- [文秘资料]缝纫工辞职报告怎么写
- [文秘资料]XXX州委书记述职报告
- [文秘资料]抓基层党建工作述职报告
- (王虎应老师讲课记录)六爻理象思维
- 八个常见投影机故障排除法
- 质量专业综合知识(中级)第一章质量管理
- 煤矿班组建设实施意见
- 我国快餐业与肯德基经营模式的比较与分
- 汽车保险杠模具标准化模架技术工艺研究
- 汽车二级维护作业团体赛比赛规程
- 装卸搬运工安全操作规程
- 高效的工作方法-刘铁
- 依据《生产安全事故报告和调查处理条例
- 2015专业PS夜景亮化效果图制作教程
- 企业劳动定额定员浅析
- 中枢神经系统医学影像学本科五年制第五
- 长城汽车参观探营第三站:研发试验中心
- 小升初语文专项训练
- 建筑工程质量检测资质分类与等级标准
- 周燕珉-我国养老社区的发展现状与规划
- 《生命里最后的读书会》读后感
- 实验室管理评审报告
- CCNA思科网院教程精华之网络基础知识




