



免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
姓名:张进 学号:03091256 班级:030913班实验六:编程实现Dijkstra 算法求最短路问题.1.需求分析:首先让用户输入一个带权的有向图,输入时可通过一对一对输入存在弧的两个弧头与弧尾顶点以及弧上的权值从而输入整个有向图。用户输入一对对弧后,我们可以采用数组的形式来进行存储每个顶点之间的权值,最后由用户输入该有向图的源点(即每个最短路径的起点),要求源点必须为刚才输入的各顶点中的某一个,如果用户输入错误,程序要给出错误信息提示并退出程序。然后,我们可以设计一个Graph这样的类,将对关系的各种操作放入其中,然后我们在主函数中调运这个类就可以实现最短路问题的求解了。2.概要设计:.构造一个新的类Graph:class Graphprivate: int arcsMAXMAX,PathMAXMAX,DMAX; int arcnum,vexnum,weight,v0; Type a,b,vexsMAX;public: void Creat_Graph(); void Show_ShortestPath(); void ShortestPath_DIJ();.结构化调用类中方法的主函数:int main()Graph G; G.Creat_Graph(); G.ShortestPath_DIJ(); G.Show_ShortestPath();return 0;3.代码实现:#include #define MAX 100#define INFINITY INT_MAX enum BOOLFALSE,TRUE; using namespace std;template class Graphprivate: int arcsMAXMAX,PathMAXMAX,DMAX; int arcnum,vexnum,weight,v0; Type a,b,vexsMAX;public: void Creat_Graph(); void Show_ShortestPath(); void ShortestPath_DIJ();template void Graph:Creat_Graph() int i,j,x,y; coutarcnum; vexnum=0; for(i=1;i=MAX;i+) for(j=1;j=MAX;j+) arcsij=INT_MAX; for(i=1;i=arcnum;i+) cout请依次输入第i条弧的弧头与弧尾的顶点以及该弧上所附带的权值:abweight; x=0; y=0; for(j=1;j=vexnum;j+) if(vexsj=a) x=j; continue; else if(vexsj=b) y=j; continue; if(x=0) vexs+vexnum=a; x=vexnum; if(y=0) vexs+vexnum=b; y=vexnum; arcsxy=weight; couta; for(i=1;i=vexnum;i+) if(vexsi=a) v0=i; break; template void Graph: Show_ShortestPath() int i,j,k; for(i=1;i=vexnum;i+) if(i=v0) continue; if(Di!=INT_MAX) cout从源点vexsv0到vexsi的最短路径为:endl; for(k=1;k=Pathi0;k+) if(k!=1) cout; for(j=1;j=vexnum;j+) if(Pathij=k) coutvexsj; cout 其最短的路径长度为:Diendl; else cout无法从源点vexsv0到达顶点vexsi.endl; coutendl;template void Graph:ShortestPath_DIJ() int v,w,finalMAX,min,i,j; for(v=1;v=vexnum;v+) finalv=FALSE; Dv=arcsv0v; Pathv0=0; for(w=0;w=vexnum;w+) Pathvw=FALSE; if(DvINT_MAX) Pathvv0=+Pathv0; Pathvv=+Pathv0; Dv0=0; finalv0=TRUE; for(i=1;i=vexnum;i+) if(i=v0) continue; min=INT_MAX; for(w=1;w=vexnum;w+) if(!finalw) if(Dwmin) v=w; min=Dw; finalv=TRUE; for(w=1;w=vexnum;w+) if(!finalw&(min+arcsvwDw)&minINT_MAX&arcsvwINT_MAX) Dw=min+arcsvw; for(j=0;j=vexnum;j+) Pathwj=Pathvj; Pathww=+Pathw0; int main()Graph G; G.Creat_Graph(); G.ShortestPath_DIJ(); G.Show_ShortestPath();return 0;4.调试分析:起先在主函数中调用类Graph时将类型参数T赋值为int从而导致用户输入的关系集合R中的元素必须为整数。经分析后将T赋值为char,当用户输入的R的元素为int时,我们可以将其转化为char在进行后续操作,从而实现对用户输入的关系R中元素的无限制。在类Graph的模板外定义成员函 G.Creat_Graph()G.ShortestPath_DIJ()G.ShortestPath_DIJ()时,由于成员函数中有类型参数存在,则需要在函数外进行模块声明,并且在函数名前缀上“类名”。5.运行结果:下图为有向图G的带权邻接矩阵,运用Dijkstra算法计算从A到其余各顶点的最短路径以及其长度。 A B C D E F 分析可知:A 10 30 100 从A到C的最短
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【正版授权】 IEC 60645-7:2025 RLV EN Electroacoustics - Audiometric equipment - Part 7: Instruments for the measurement of auditory evoked potentials
- 初中数学三角形的概念(课件)+人教版数学八年级上册
- 新解读《GB-T 30568-2014锆及锆合金锻件》
- 重庆山城骑士课件
- 新解读《GB-T 4131-2014水泥的命名原则和术语》
- 新解读《GB 2494-2014固结磨具 安全要求》
- 完形填空-说明文和议论文(复习讲义)-2026年高考英语一轮复习原卷版
- 重工绕线基础知识培训课件
- 醉翁亭记教学课件
- 酿酒机器人编程知识培训课件
- GB/T 5162-2021金属粉末振实密度的测定
- GB/T 2820.4-2009往复式内燃机驱动的交流发电机组第4部分:控制装置和开关装置
- GB/T 12755-2008建筑用压型钢板
- GB 1886.45-2016食品安全国家标准食品添加剂氯化钙
- 26个英文字母(课堂PPT)
- 《生产与运作管理(第四版)》整套教学课件
- 无脊椎动物类群三腔肠动物门
- 生活离不开规则观课报告
- 硫化氢考试题库
- 监控中心主任岗位职责
- 住院医师规范化培训申请表
评论
0/150
提交评论