



免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
交运0701小组成员:胡连胜 1101070120赵桂湖 1101070107周文彬 1101070122王 魁 1101070123单源最短路径问题问题描述给定一个带权有向图 G=(V,E) ,其中每条边的权是一个非负实数。另外,还给定 V 中的一个顶点,称为源。现在我们要计算从源到所有其他各顶点的最短路径长度。这里的长度是指路上各边权之和。这个问题通常称为单源最短路径问题。单源最短路径问题解决方案:Dijkstra提出按各顶点与源点v间的路径长度的递增次序,生成到各顶点的最短 路径的算法。既先求出长度最短的一条最短路径,再参照它求出长度次短的一条最短路径,依次类推,直到从源点v 到其它各顶点的最短路径全部求出为止。 问题的提出: 给定一个带权有向图G与源点v,求从v到G中其它顶点的最短路径。限定各边上的权值大于或等于0。 求单源最短路径的具体步骤将图G中所有的顶点V分成两个顶点集合S和T。以v为源点已经确定了最短路径的终点并入S集合 中,S初始时只含顶点v,T则是尚未确定到源点v最短路径的顶点集合C语言源程序代码如下:#include #include int n=0; /*结点个数*/int prev100; /*记录最短路径到i的前一个顶点*/int s101; /*/float a100100; /*记录边的权值*/float dist100; /*记录从源点到i的相应最短路径*/#define MAX_VALUE 100000.0void dijkstra(int v) int i,j; if(vn) return; /*初始设置*/ for(i=1;i=n;i+) disti=avi; /*初始时从源点到i的最短路径设为从源点到i的权值*/ si=1; /*si=false*/ if(disti=MAX_VALUE) previ=0; /*从源点到i没有通路*/ else previ=v; /*从源点到i有通路时,最短路径前一个结点设为源点*/ distv=0; /*源点到源点的最短路径为0*/ sv=0; /*sv=true*/ /*为下面循环中源点不参加比较做准备*/ /*中心部分*/ for(i=1;in;i+) float temp=MAX_VALUE; int u=v; /*找出一个剩余结点中到源点最短的结点*/ for(j=1;j=n;j+) if(sj=1) & (distjtemp) /*如果该点不是源点并且源点到j点路径是最短*/ u=j; /*u记录最短路径的点*/ temp=distj; /*记录源点到j点的最短路径*/ su=0; /*su=true*/ /*u点是下面进行比较的点*/ /*找出通过U点是否有更短的路径*/ for(j=1;j=n;j+) if(sj=1) & (aujMAX_VALUE) float newdist=distu+auj; if(newdistdistj) /*源点到u的路径+u到j的路径源点到j的路径*/ distj=newdist; /*更改源点到j的路径长度*/ prevj=u; /*更改源点到j的最短路径中,j的前一个结点*/ main() int i,j,v; float temp; printf(Please input number of point:n); scanf(%d,&n); /*输入结点的个数*/ printf(Now input length i to j:n); for(i=1;i=n;i+) for(j=1;jj的权值*/ if(aij=0.0) aij=MAX_VALUE; /*输入为0表示没有通路,改为最大值*/ if(i=j) aij=0.0; /*i-i的权值为0*/ /* for(i=1;i=n;i+) for(j=1;j=n;j+) printf(%ft,aij); printf(n); */ printf(Now input v point(0point=%d):n,n); scanf(%d,&v); /*输入起始结点*/ dijkstra(v); printf(-n); /*设置输出*/ for(i=1;i=n;i+) if(i!=v & distiMAX_VALUE) /*源点到源点;源点到某点最长路径为无穷大的都不需要输出*/ printf(nfrom %d to %d,the shortest way is %g fa
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 公司每月生日会策划方案
- 2025年职业教育与成人继续教育专业能力考核试题及答案
- 2025年医学影像技术考试试卷及答案
- 2025年社会保障与就业考试题及答案
- 畜禽粪污资源化技术-洞察及研究
- 2025年教育信息化与学习平台构建考试试卷及答案
- 2025年环境工程师资格考试试卷及答案
- 2025年广告与传播专业考试试题及答案
- 2024年度浙江省二级造价工程师之建设工程造价管理基础知识提升训练试卷B卷附答案
- 2024年度浙江省二级注册建筑师之法律法规经济与施工题库附答案(基础题)
- (完整版)传热学期末考试试题
- JCT587-2012 玻璃纤维缠绕增强热固性树脂耐腐蚀立式贮罐
- Python数据分析与数据挖掘 课件 第6、7章 Pandas基础与应用、Matplotlib
- 玻璃体手术并发症的预防及处理
- 2023年医学高级职称-中医肛肠(医学高级)考试历年高频考点试题含答案
- 爬架拆除技术交底
- pergeos软件教程评价许可介绍
- 密封条范文模板(A4打印版)
- 出租车 专业部分考核试题 城市客运企业主要负责人和安全生产管理人员安全考核基础题库
- GB/T 9634.3-2002铁氧体磁心表面缺陷极限导则第3部分:ETD和E形磁心
- GB/T 8478-2008铝合金门窗
评论
0/150
提交评论