下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验三 单源最短路径一、实验目的及要求掌握贪心算法的基本思想用c程序实现单源最短路径的算法二、实验环境Window下的vc2010三、实验内容1、有向图与单源点最短路径2、按路径长度非降的次序依次求各节点到源点的最短路径3、Dijkstra算法四、算法描述及实验步骤设给定源点为Vs,S为已求得最短路径的终点集,开始时令S=Vs。当求得第一条最短路径(Vs,Vi)后,S为Vs,Vi。根据以下结论可求下一条最短路径。设下一条最短路径终点为Vj,则Vj只有:源点到终点有直接的弧;从Vs出发到Vj的这条最短路径所经过的所有中间顶点必定在S中。即只有这条最短路径的最后一条弧才是从S内某个顶点连接到S外的
2、顶点Vj。若定义一个数组distn,其每个disti分量保存从Vs出发中间只经过集合S中的顶点而到达Vi的所有路径中长度最小的路径长度值,则下一条最短路径的终点Vj必定是不在S中且值最小的顶点,即:disti=Mindistk|VkV-S利用公式就可以依次找出下一条最短路径。在程序中c表示带权邻接矩阵,dist表示顶点到源点的最短路径,p记录顶点到源点最短路径的前驱节点,u源点,函数Way是递归的构造出最短路径的次序。五、实验结果程序执行的结果:六、源代码#include #includeusing namespace std;#define MAX 999void getdata(int *
3、c,int n)int i,j;int begin,end,weight;for (i=1;i=n;i+)for (j=1;j=n;j+)if(i=j)cij=0;elsecij=MAX;do coutbegin;if(begin=-1) break;cinendweight;cbeginend=weight; while(begin!=-1);void Dijkstra(int n,int v ,int *dist,int *prev,int *c)bool sMAX;int i,j;for (i=1;i=n;i+)disti=cvi;/从源点到各点的值si=false;if(disti=M
4、AX) previ=0;/最大值没有路径else previ=v;/前驱为源点distv=0;sv=true;for (i=1;i=n;i+) int temp=MAX;int u=v;for(j=1;j=n;j+)if(!sj)&(distjtemp) u=j;temp=distj;/不在集合里,值temp,选最小值su=true;for (j=1;j=n;j+) if(!sj)&(cujMAX)int newdist=distu+cuj;if(newdist1;i-)pathi=prevpathi+1;/构造路径m-;for (i=m;i=end;i+) coutpathi;/输出路径coutbb endl;void main()int n,i;int v=1;coutn;int *dist=new int n+1;int *prev=new int n+1;int *c;c=new int *n+1;for (i=0;i=n;i+)ci=new int n+1;getdata(c,n);/获取数据int begin=1,end;coutbeginend;v=begin;Dijks
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 数学硕士就业方向
- 齿轮厂复印机管理制度
- 某预制构件厂奖惩公示规范
- 河南省信阳市示范名校2026届生物高一下期末检测模拟试题含解析
- 预防培训课程设计讲解
- 仓库消防安全培训指南
- 医学人文评价指标的动态优化机制
- 广西南宁市二中2026届高一生物第二学期期末教学质量检测试题含解析
- 吉林省延边朝鲜族自治州延吉二中2026届生物高一下期末综合测试试题含解析
- 2026年科技馆场馆三级安全教育培训试题(答案)
- 2026年人教部编版语文五年级下册教学计划(含进度表)
- 风电网络安全培训课件
- 2026年齐齐哈尔高等师范专科学校单招职业适应性考试题库附答案
- 起重吊装作业安全操作规程完整
- 2026年黑龙江农业工程职业学院单招职业倾向性测试题库附答案
- 2025年义务教育信息技术新课程标准考试测试题及部分答案
- 注塑现场操作培训大纲
- 《土木工程智能施工》课件 第1章 绪论
- 2025新修订监察法实施条例考试试卷试题及参考答案
- 垃圾填埋场土地复垦技术方案
- GB/T 16855.1-2025机械安全安全控制系统第1部分:设计通则
评论
0/150
提交评论