



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include stdio.h#define max_num 20typedef enum DG,DN,UDG,UDNGraphkind;typedef struct ArcCellint adj;char *info;ArcCell,AdjMatrixmax_nummax_num;typedef structchar vexsmax_num;/顶点向量 AdjMatrix arcs;/定义邻接矩阵int vexnum;/定义图当前的定点数int arcnum;/定义图当前的弧数 Graphkind kind;/图的种类标志MGraph;void CreateDG_DN(MGraph *G);void CreateUDN_UDG(MGraph *G);void CreateGraph(MGraph *G);int LocateVex(MGraph *G,char c);void DisplayGraph(MGraph *G);void main()MGraph G; CreateGraph(&G); DisplayGraph(&G);void CreateGraph(MGraph *G) printf(输入图的类型(DG,DN,UDG,UDN对应选择0,1,2,3):); scanf(%d,&G-kind); switch(G-kind) case DG:CreateDG_DN(G);break; case DN:CreateDG_DN(G);break; case UDG:CreateUDN_UDG(G);break; case UDN:CreateUDN_UDG(G);break; default:break; void CreateDG_DN(MGraph *G)int i,j,k,w; char v2,c10;if(G-kind=0)printf(CreateDG(有向图)n);elseprintf(CreateDN(无向图)n);printf(输入顶点数和边数(弧数):n); scanf(%d%d,&G-vexnum,&G-arcnum); printf(顶点数为%d,边数(弧数)为%dn,G-vexnum,G-arcnum); printf(输入每个顶点的数据:n); scanf(%s,c);/输入顶点信息 for(i=0;ivexnum;i+)G-vexsi=ci;for(i=0;ivexnum;i+) for(j=0;jvexnum;j+)G-arcsij.adj=0; G-=NULL;/可以自己定义赋值/初始化矩阵for(k=0;karcnum;k+) printf(输入邻接第%d条边(弧)两顶点:,k+1);scanf(%s,v);/printf(输入边权值:);/scanf(%d,&w);i=LocateVex(G,v0);j=LocateVex(G,v1);G-arcsij.adj=1;if(G-kind=1) G-arcsji=G-arcsij;/无向图是对角矩阵void CreateUDN_UDG(MGraph *G)int i,j,k,w;char v2,c10;if(G-kind=3)printf(CreateUDN(无向网)n);elseprintf(CreateUDG(有向网)n);printf(输入顶点数和边数(弧数):n);scanf(%d%d,&G-vexnum,&G-arcnum);printf(顶点数为%d,边数(弧数)数为%dn,G-vexnum,G-arcnum);printf(输入每个顶点的数据:n);scanf(%s,c);/输入顶点信息for(i=0;ivexnum;i+)G-vexsi=ci;for(i=0;ivexnum;i+)for(j=0;jvexnum;j+)G-arcsij.adj=0;G-=NULL;/可以自己定义赋值/初始化矩阵for(k=0;karcnum;k+) printf(输入邻接第%d条边(弧)两顶点:,k+1);scanf(%s,v);printf(输入边(弧)权值:);scanf(%d,&w);i=LocateVex(G,v0);j=LocateVex(G,v1);G-arcsij.adj=w;if(G-kind=3) G-arcsji=G-arcsij;/无向图是对角矩阵int LocateVex(MGraph *G,char c) int i;for(i=0;ivexnum;i+) if(G-vexsi=c) return i; return -1;void DisplayGraph(MGraph *G) switch(G-kind) case DG:printf(有向图邻接矩阵,其中1表示弧段联通,0为非联通n);break; case DN:printf(无向图邻接矩阵,其中1表示边联通,0为非联通n);break; case UDG:printf(有向网邻接矩阵,其中非零值表示各相邻接弧段的权值n);break; case UDN:printf(无向网邻接矩阵,其中非零值表示各
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 社区素质提升项目的咨询合同
- 抵押物转移协议范本
- 2025年消防执业资格考试题库:消防应急通信保障应急预案演练试题
- 2025年征信信息分析师认证考试:征信数据挖掘与征信系统试题集
- 2025年征信考试题库解析:征信信用修复流程案例分析试题
- haccp 培训合同样本
- 业主自住装修出租合同标准文本
- 农村住房出售合同标准文本
- 创业园投资合同样本
- 六座车买卖合同样本
- 专题五 战争与文化交锋 高考历史二轮复习专项提分训练(含答案)
- 人教版二年级数学下册第三单元 图形的运动(一)标准检测卷(含答案)
- 2025年山东省淄博市张店区中考一模历史试题(含答案)
- 2025年内蒙古中考一模英语试题(原卷版+解析版)
- 【湛江】2025年中国热带农业科学院农产品加工研究所第一批招聘工作人员30人(第1号)笔试历年典型考题及考点剖析附带答案详解
- 银行案件防控课件
- 山东省东营市东营区胜利第一初级中学2024-2025学年九年级下学期一模英语试卷(含答案无听力原文及音频)
- 临床决策支持系统在路径优化中的实践案例
- 成人重症患者人工气道湿化护理专家共识 解读
- 2024年湖北省中考地理生物试卷(含答案)
- 2024国家粮食和物资储备局垂直管理系事业单位招聘笔试参考题库含答案解析
评论
0/150
提交评论