全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#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餐厅家具采购合同模板
- 公司数据安全保障承诺书8篇
- 项目管理流程标准模板项目进度与质量双控
- 企业人力资源管理绩效评价体系
- 部门年度预算制定工具
- 项目进度与品质双保障承诺书3篇
- 中国洗衣机不锈钢组合螺钉项目投资可行性研究报告
- 电池底壳行业深度研究报告
- 中国波纹电箱项目投资可行性研究报告
- 2025年乡村会计理论考试题及答案
- 哈三中2025-2026学年高一上学期期中物理试卷和答案
- 2025江苏南通市通州区石港镇招聘便民服务中心人员2人笔试考试参考题库及答案解析
- 单位消防安全管理档案样本模板
- 国开2025年《分析化学(本)》形考任务1-3答案
- 2025入党积极分子预备党员考试题库及答案(5份)
- 2025四川成都空港兴城投资集团有限公司下属企业招聘一线岗位104人考试参考题库及答案解析
- 直播诈骗课件
- 啤酒销售基本知识培训课件
- 2025-2026学年统编版(2024)小学语文二年级上册期中综合测试卷及答案
- 2025年沈阳社区考试真题及答案
评论
0/150
提交评论