




已阅读5页,还剩9页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
_数据结构实验三 图的应用(代码&测试界面)/Traffic_Inquiry.h#include #include #define FINITY 999 /用999代表无穷大 #define M 20 /城市最大个数 typedef struct /邻接矩阵类型定义 char name8;CityNode; /城市信息结点的结构体(顶点值类型)typedef int distype; /权值类型-距离 typedef int costype; /权值类型-费用 typedef struct CityNode citysM; /顶点信息域 distype disMM; /领接矩阵-距离costype cosMM; /邻接矩阵-费用int n, e; /图中顶点总数与边数 Mgraph; /建立图的邻接矩阵存储结构 void CreateGraph(Mgraph *g)int i, j, k; double d, c;printf(请输入城市数与路径数:);scanf(%d %d,&g-n, &g-e); for(i=0; in; i+) /读入图的顶点数 printf(请输入第%d个城市名称:,i); scanf(%s,); for(i=0; in; i+) /初始化邻接矩阵 for(j=0; jn; j+) if(i=j) g-disij=0;g-cosij=0;else g-disij=FINITY;g-cosij=FINITY; printf(n城市名称录入完毕,录入结果:nt); for(i=0; in; i+) printf(%d-%st,i,); printf(n录入路径的权值信息,示例:0 1 34 40); printf(代表%s到%s的距离为34千米,费用为40元n,,);for(k=0; ke; k+) /读入网络中的边scanf(%d %d %lf %lf,&i, &j, &d, &c);g-disij=g-disji=d;g-cosij=g-cosji=c; /Dijkstra算法求解单源最短路径 typedef enumFALSE,TRUE boolean; /FALSE为0,TRUE为1 void dijkstra(Mgraph g, int v0,const int q) /函数参数:图的领接矩阵g;源点v0;int dM;/权值(距离或费用)向量类型int pM;/路径类型boolean finalM; /表示当前元素是否已经求出最短路径int i,k,v,min;/第一步,初始化集合s与距离向量dfor (v=0; vg.n; v+)finalv=FALSE;if(q) dv=g.disv0v;else dv=g.cosv0v;if (dvFINITY & dv!=0)pv=v0; else pv=-1; /v无前驱finalv0=TRUE; dv0=0; /初始时s中只有v0一个结点/第二步,依次找出n-1个结点加入s中for(i=1; ig.n; i+)min=FINITY;for(k=0;kg.n;+k) /找最小边入结点 if(!finalk&dkmin) /!finalk表示k还在V-S中 v=k;min=dk;if(minFINITY)if(q) printf( %s 到 %s 的最短距离为:%d千米n,,,min);else printf( %s 到 %s 的最小费用为:%d元n,,,min);else if(min=FINITY) return;finalv=TRUE; /v加入S/第三步,修改V-S中各节点的距离for(k=0;kg.n;+k)if(!finalk&(min+g.disvkdk)dk=min+g.disvk;pk=v; void floyd(Mgraph g,int q) /Floyd方法求所有顶点对间的最短路径(q用于判断参与算法的是距离还是费用) int eMM; /权值(距离或费用)向量类型 int pMM; /路径类型 int i, j, k; if(q) memcpy(e,g.dis,M*M*sizeof(int); else memcpy(e,g.cos,M*M*sizeof(int); for(i=0;ig.n;i+) /初始化 for(j=0;jg.n;j+)if(i!=j & eijFINITY) pij=i; else pij=-1; for(k=0;kg.n;k+) /递推求解每一对顶点间的最短距离for(i=0;ig.n;i+)for(j=0;j(eik+ekj) eij=eik+ekj; pij=k; printf(n);for(i=0;ig.n;i+) for(j=0;jg.n;j+) if(i!=j&eij!=0&eijFINITY) if(q) printf( %s 到 %s 的最短距离为:%dkm。n,,,eij);else printf( %s 到 %s 的最小费用为:%d元。n,,,eij);printf(n);void refer(Mgraph g, int *v0)for(int i=0; i%st,i,);printf(n请输入查询城市序号:);scanf(%d,v0);if(!(*v0g.n)printf(你的输入有误!n);refer(g,v0);int menu () int set;printf(t n); printf(t 操作目录 n); printf(t n); printf(t 欢 1.查询某地到它市最短路径 n); printf(t 迎 n); printf(t 使 2.查询某地到它市最小费用 n); printf(t 用 n); printf(t 交 3.显示各大城市间最短路径 n);printf(t 通 n); printf(t 查 4.显示各大城市间最小费用 n);printf(t 询 n); printf(t 系 5.进入管理员模式修改数据 n);printf(t 统 n); printf(t 6.退出交通查询及管理系统 n); printf(t n); printf(t n); printf(n请根据你的需求选择操作:); scanf(%d,&set);printf(n);return set; /main.c#include #include #include #include Traffic_Inquiry.hint main() int v0;int set=1;Mgraph g; /默认交通图 g.n=8; g.e=11;for(int i=0; ig.n; i+) /初始化邻接矩阵 for(int j=0; jg.n; j+) if(i=j) g.disij=0;g.cosij=0;else g.disij=FINITY;g.cosij=FINITY; strcpy(,太原); strcpy(,成都);strcpy(,上海); strcpy(,北京);strcpy(,深圳); strcpy(,重庆);strcpy(,杭州); strcpy(,厦门);g.cos01=g.cos10=99; g.dis01=g.dis10=19;g.cos03=g.cos30=12; g.dis03=g.dis30=51;g.cos12=g.cos21=54; g.dis12=g.dis21=14; g.cos17=g.cos71=123; g.dis17=g.dis71=13;g.cos24=g.cos42=201; g.dis24=g.dis42=61;g.cos27=g.cos72=15; g.dis27=g.dis72=25;g.cos36=g.cos63=77; g.dis36=g.dis63=77;g.cos35=g.cos53=45; g.dis35=g.dis53=15;g.cos45=g.cos54=14; g.dis45=g.dis54=17;g.cos76=g.cos67=25; g.dis76=g.dis67=87;g.cos75=g.cos57=66; g.dis75=g.dis57=12;while(set)switch(menu()case 1:refer(g,&v0);dijkstra(g,v0,1);break;case 2:refer(g,&v0);dijkstra(g,v0,0);break;case 3:floyd(g,1);break; /距离 case 4:floyd(g,0);break; /费用 case 5:CreateGraph(&g);break;case 6:set=0;printf(tttt欢迎下次使用!n);break;default:printf(无该选项对应的操作!n); system(pause);system(cls
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 创新平台建设模式-洞察及研究
- 农林系统碳汇提升-洞察及研究
- 轨道空间站结构优化-洞察及研究
- 2025年事业单位笔试-河北-河北医学基础知识(医疗招聘)历年参考题库典型考点含答案解析
- 预加载安全防护措施-洞察及研究
- 2025年事业单位笔试-山东-山东超声医学(医疗招聘)历年参考题库典型考点含答案解析
- 2025年事业单位笔试-天津-天津卫生事业管理(医疗招聘)历年参考题库典型考点含答案解析
- 数字媒介下的叙事融合-洞察及研究
- 消防干部面试题目及答案
- 项目管理面试题目及答案
- 初中英语新课程标准测试试题及答案3套
- 如何开展课题研究
- 英语选修4单词表
- 炼钢厂电工应知应会考试题库500题(含各题型)
- GB/T 5069-2007镁铝系耐火材料化学分析方法
- GB/T 3840-1991制定地方大气污染物排放标准的技术方法
- 旅游区奖惩制度管理办法
- 小学语文人教六年级上册《童年》整书阅读课件
- 幼儿舞蹈《蜗牛》舞蹈教案
- 生物药剂学:第七章 非线性药物动力学
- 组合式空调机组各功能段介绍(课堂PPT)
评论
0/150
提交评论