建立通信网络.doc_第1页
建立通信网络.doc_第2页
建立通信网络.doc_第3页
建立通信网络.doc_第4页
建立通信网络.doc_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

滨江学院数据结构课程设计 题 目 建立通信网络 学 号 20112346051学生姓名 刘 勇 院 系 计算机系专 业 11级 网络工程指导教师 宣文霞二一二 年 12 月 10 日 建立通信网络一。需求分析:题目:最小生成树kruskal算法的实现问题描述:任意创建一个图,用kruskal算法求去他的最小生成树。举例:若要在n个城市之间建设通信网络,只需要架设n-1条线路即可。如何以最低的经济代价建设这个通信网,我们可以用求kruskal算法求这个网的最小生成树来解决这个问题。(1) 建立一个图,其存储方式可以采用邻接矩阵形式,需要定义两个数组,一个存储顶点,一个存储边,存储边的数组表明节点间的连通关系和边的权值;(2)利用克鲁斯卡尔算法求网的最小生成树;(3)按顺序输出生成树中各条边以及它们的权值。输入的形式和输入值的范围:输入的数值有各顶点,两顶点之间的权值。输入的顶点最多不能大于20个。输出的形式:先输出图的邻接矩阵,输出权值的排序,最后输出最小生成树的各边和权值。程序所能达到的功能;用户可以任意的输入一个顶点小于20的图,该程序可以求出图的邻接矩阵和最小生成树。D测试数据:6 5 1 2 1 2 3 2 3 4 3 4 5 4 1 5 6 3 2 4 5输出结果: V1, V2 1 V2, V3 2 V3, V4 3 V4,V5 4 二。概要分析 1 本程序中用到的所有抽象数据类型的定义ADT Graph 数据对象V:V是具有向他特性的数据元素的集合,称为顶点集。 数据关系对象: R=VRVR=|v.w且P(V,W),表示V到W的弧,谓词P(V,W)定义了弧的意义或信息 基本操作P: CreateCraph(&G,V,VR); 初始条件:V是图的顶点集,VR是图中的弧的集合。 操作结果:按V和VR的定义构造图G.MiniSpanTree(G);初始条件:图G存在。操作结果:求出图G的最小生成树Sort(edge* ,MGraph *);初始条件:图G存在,edge存在。操作结果; 对edge进行了排序。Swapn(edge *, int x, int y);初始条件:edge存在,x,y是两条边操作结果:交换了x,y这两条边。Find(int *, int );初始条件:edge存在:操作结果:对这些边进行遍历查找。2主程序的流程int main(void)/主函数 MGraph *G;程序中定义一个图G = (MGraph*)malloc(sizeof(MGraph);为这个图动态分配存储空间if (G = NULL)printf(memory allcation failed,goodbye);exit(1); 如果这个图不存在系统将会非正常结束 CreatGraph(G);创建一个图输入总边数和总顶点输入各顶点和顶点之间的权值输出该图的邻接矩阵 MiniSpanTree(G);求该图的最小生成树 对权值进行排序输出排序后的权值和顶点对各边依次进行判断,是否存在回路,如果没有回路,则输出这条边,否则,则不输出system(pause);程序运行暂停return 0;3序模块之间的层次(调用)关系 主函数模块图构建模块最小生成树模块3.详细设计#define M 20#define MAX 20规定该程序所能创建图的最大顶点数为20个点typedef struct /用结构体定义边edge;typedef struct/用结构体定义数组AdjMatrixMAXMAX;typedef struct/用结构体定义一个图MGraph; 函数申明 void CreatGraph(MGraph *); /图构建函数申明 void sort(edge* ,MGraph *); /权值排序函数申明void MiniSpanTree(MGraph *); /生成最小树函数的申明int Find(int *, int );/ 尾顶点查找void Swapn(edge *, int, int);/权值、头顶点、尾顶点交换void CreatGraph(MGraph *G)/构件图printf(请输入边数和顶点数:n);G-arcij.adj = G-arcji.adj = 0;/先把矩阵中所有元素赋值为0for ( i = 1; i arcnum; i+)/输入边和权值 G-arcnm.adj = G-arcmn.adj = 1;/将输入的顶点记录为1getchar();printf(请输入%d与%d之间的权值:n, n, m); printf(邻接矩阵为:n);输出邻接矩阵以上是图的创建,邻接矩阵的建立将辅助权值排序void MiniSpanTree(MGraph *G)/生成最小生成树 sort(edges, G);/sort函数调用,对权值进行排序void sort(edge edges,MGraph *G)/对权值进行排序 void Swapn(edge *edges,int i, int j)/交换权值 以及头和尾 在对权值排序时,若(edgesi.weight edgesj.weigh)调用函数swapn交换这两条边的权值以及头和尾顶点 以上是对权值进行排序,排序之后将有利于回路的判断,从而求出最小生成树 printf(最小生成树为:n);for (i = 1; i arcnum; i+)/核心部分 n = Find(parent, edgesi.begin);m = Find(parent, edgesi.end);if (n != m)/判断是否有回路,如果有,舍弃 parentm = n;printf( %dn, edgesi.begin, edgesi.end, edgesi.weight);int Find(int *parent, int f)/找尾 while ( parentf 0)f = parentf; return f; 关键代码输出最小生成树以下是主函数部门int main(void)/主函数 MGraph *G;G = (MGraph*)malloc(sizeof(MGraph);if (G = NULL)printf(memory allcation failed,goodbye);exit(1); CreatGraph(G); MiniSpanTree(G);system(pause);return 0;主函数通过调用不同的函数模块来实现的功能以下是函数关系的调用图 Main( ) _ CreatGraph() MiniSpanTree( ) _ Sort ( ) Find( ) Swapn( )4.调试分析1由于对函数调用关系不是非常清楚,导致在程序设计的时候思路不是非常的清晰2该程序只能满足图顶点比较少的最小生成树的实现,如果用户要求更大的空间,可以在创建图的时候开辟更大的空间。3在程序输入的时候,必须顶点数值小的先输入,否则程序将会出错。这也是程序应该改进的地方。4算法的时空分析 1,对矩阵的初始化,设输入一个n个顶点的图,那个将要对矩阵的nxn个元素进行初始化,所以时间复杂度为O(N2) 2,输入权值和边的时间复杂度为O(n),所以构建图的时间复杂度为O(N2+N) 3.矩阵输出的时间复杂度为O(N2) 。空间复杂度为S(N2) 4在求最小生成树函数中,对边进行标记的时间复杂度为O(N2)。对权值进行排序的时间复杂度为O(N2),对parent数组赋值的时间复杂度为o(n),所以该函数的时间复杂度为O(2N2+N)5 过这次课程设计,一方面我加深对课内所学的有关数据的逻辑结构和存储表示、数据结构的选择和应用、算法的设计和时空分析等课程基本内容的理解,另一方面,使我在序设计方法(如抽象数据类型、结构化分析、模块化设计和结构化设计)、C语言程序调试和测试方面受到比较系统的严格的训练。 5.用户使用说明1,输入图的顶点数和边数2任意输入两个图中连接的顶点3输入这两个顶点的权值具体步骤图如下 输入完数据之后,按enter键将会显示以下结果 最后按任意键退出,可以进行其他图最小生成树的实现6.测试结果这里提供其他几组测试数据:输入的数据: 输出数据输入数据: 输出数据:7. 附录;源程序#include#include#define M 20#define MAX 20typedef struct int begin; /头顶点int end; /末顶点int weight; /权值edge;typedef structint adj;int weight;/权值AdjMatrixMAXMAX;typedef structAdjMatrix arc;int vexnum, arcnum;/顶点 弧MGraph; /函数申明 void CreatGraph(MGraph *); /图构建 void sort(edge* ,MGraph *); /权值排序void MiniSpanTree(MGraph *); /生成最小树int Find(int *, int );/ 尾顶点查找void Swapn(edge *, int, int);/权值、头顶点、尾顶点交换void CreatGraph(MGraph *G)/构件图int i, j,n, m;printf(请输入边数和顶点数:n);scanf(%d %d,&G-arcnum,&G-vexnum); for (i = 1; i vexnum; i+)/初始化图for ( j = 1; j vexnum; j+)G-arcij.adj = G-arcji.adj = 0;for ( i = 1; i arcnum; i+)/输入边和权值 printf(请输入有边的2个顶点n);scanf(%d %d,&n,&m);while(n G-vexnum | m G-vexnum)printf(输入的数字不符合要求 请重新输入:n);scanf(%d%d,&n,&m);G-arcnm.adj = G-arcmn.adj = 1;getchar();printf(请输入%d与%d之间的权值:n, n, m);scanf(%d,&G-arcnm.weight); printf(邻接矩阵为:n);for ( i = 1; i vexnum; i+) for ( j = 1; j vexnum; j+)printf(%d ,G-arcij.adj);printf(n);void sort(edge edges,MGraph *G)/对权值进行排序 int i, j;for ( i = 1; i arcnum; i+)for ( j = i + 1; j arcnum; j+)if (edgesi.weight edgesj.weight)Swapn(edges, i, j); printf(权排序之后的为:n);for (i = 1; i arcnum; i+)printf( %dn, edgesi.begin, edgesi.end, edgesi.weight);void Swapn(edge *edges,int i, int j)/交换权值 以及头和尾 int temp; temp = edgesi.begin; edgesi.begin = edgesj.begin; edgesj.begin = temp; temp = edgesi.end; edgesi.end = edgesj.end; edgesj.end = temp; temp = edgesi.weight; edgesi.weight = edgesj.weight; edgesj.weight = temp;void MiniSpanTree(MGraph *G)/生成最小生成树 int i, j, n, m;int k = 1;int parentM;edge edgesM;for ( i = 1; i vexnum; i+)for (j = i + 1; j vexnum; j+)if (G-arcij.adj = 1)edgesk.begin = i;edgesk.end = j;edgesk.weight = G-arcij.weight;k+; sort(edges, G); for (i = 1; i arcnum; i+)parenti = 0; printf(最小生成树为:n);for (i = 1; i arcnum; i+)/核心部分 n = Find(parent, edgesi.begin);m = Find(parent, edgesi.end);if (n != m)/判断是否有回路,如果有,舍弃 parentm = n;printf( %dn, edgesi.begin,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论