- 1、本文档共33页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
最短路径-SPL
最短路径 我们需要解决的问题 例1:输入起点,终点,求其最短路径? 如3-5 思路 Relaxation(松弛操作) 松弛操作的原理是著名的定理:“三角形两边之和大于第三边”,在信息学中我们叫它三角不等式。所谓对i,j进行松弛,就是判定是否d[j]d[i]+w[i,j],如果该式成立则将d[j]减小到d[i]+w[i,j],否则不动。 procedure relax(u,v,w:integer);//不需要单独写成过程 begin if dis[u]+wdis[v] then begin dis[v]:=dis[u]+w; pre[v]:=u; end end; 图的常用数据结构结构----邻接矩阵(静态) 图的常用数据结构结构----邻接表(动态) 邻接表的定义 n个顶点e条边的有向图,它的邻接表表示中必然有n个顶点结点和e条边的结点。 Const maxvertexnum=100; { 设置最大顶点数 } Type vertextype=char; { 设置顶点类型 } link=^node; node=record {连接表结点定义} adj:integer; {邻接点域} next:link; { 结点链域 } end; vnode=record { 图的顶点结点定义 } vertex: vertextype; { 顶点域 } firstedge: link; { 表头链域 } end; graph=array[1..maxvertexnum] of vnode; Contents 1、Dijkstra算法 问题分析 处理步骤 处理步骤 代码框架 代替集合S,用来保存已求得最短路径的终点集合,即如果s[j]=0表示顶点Vj不在集合中,反之,s[j]=1表示顶点Vj已在集合中)。 Procedure Dijkstra(GA,dist,path,i); {求Vi到图G中其余顶点最短路径,GA为图邻接矩阵,dist和path为变参,path的基类型为集合} Begin For j:=1 To n Do Begin {初始化} If ji Then s[j]:=0 Else s[j]:=1; dist[j]:=GA[i,j]; If dist[j]maxint Then path[j]:=[i]+[j] Else path[j]:=[ ]; End; 代码框架 算法局限性 对于不含负权边的图求单源最短路径,Dijkstra算法是最高效的。 Dijkstra 算法只能适合权为正值的情况,但当权为负值时,是Dijkstra 算法爱莫能助? 分析:Dijkstra每次选的是当前能连到的边中权值最小的,在正权图中这种贪心是对的,但是在负权图中就不是这样了。沿着一个负权回路再走一次总是能更小,…… 练习:最优乘车(travel) 【问题描述:】 H城是一个旅游胜地,每年都有成千上万的人前来观光。为方便游客,巴士公司在各个旅游景点及宾馆,饭店等地都设置了巴士站并开通了一些单程巴士线路。每条单程巴士线路从某个巴士站出发,依次途经若干个巴士站,最终到达终点巴士站。一名旅客最近到H城旅游,他很想去S公园游玩,但如果从他所在的饭店没有一路巴士可以直接到达S公园,则他可能要先乘某一路巴士坐几站,再下来换乘同一站台的另一路巴士, 这样换乘几次后到达S公园。现在用整数1,2,…N 给H城的所有的巴士站编号,约定这名旅客所在饭店的巴士站编号为1…S公园巴士站的编号为N。写一个程序,帮助这名旅客寻找一个最优乘车方案,使他在从饭店乘车到S公园的过程中换车的次数最少。【输入:】第一行有两个数字M和N(1=M=100 1N=500),表示开通了M条单程巴士线路,总共有N个车站。从第二行到第M+1行依次给出了第1条到第M条巴士线路的信息。其中第i+1行给出的是第i条巴士线路的信息,从左至右按运行顺序依次给出了该线路上的所有站号相邻两个站号之间用一个空格隔开。【输出:】 一行。如果无法乘巴士从饭店到达S公园,则输出N0,否则输出你的程序所找到的最少换车次数,换车次数为0表示不需换车即可到达·【样例输入:】3 76 74 7 3 62 1 3 5【样例输出:】2 2、Bellman Ford Bellman-Ford是在Dijkstra算法上的改进。在dijstra基础上,判断是否有负权回路再做一次松弛操作,也就是说如果存在一条边(u,
您可能关注的文档
- 悬振锥面选矿机介绍.pdf
- 我的祖先名叫炎黄.ppt
- 我眼中的妙玉.doc
- 我的祖先名叫炎黄-完成版.ppt
- 打造生命:龙脊壮族竖房活动分析(郭立新).pdf
- 我的祖先身披锁链来到美国--米歇尔演讲.pdf
- 把苹果敷在脸上 居然有这种效果 真是太神奇了.pdf
- 挫折面前11.ppt
- 收藏:这几张硬币收藏界的“祖宗”一枚就够吃一辈子!.pdf
- 教你如何在秋季保护自己的嘴唇.doc
- 2024年中国石油化工股份有限公司广州应届高校毕业生招聘高频考题难模拟试题附带答案完整版附答案【完整.docx
- 2023-2024年四川省新津县《执业药师之西药学专业一》考试【达标题】.docx
- 2024年上海西门子移动通信有限公司招聘3人历年(高频重点提升专题训练)附带答案完整题库附参考答案(.docx
- 2024年RTE和AI融合生态洞察报告-InfoQ研究中心.docx
- 年度品牌战略观察2025-oi咨询-202501.docx
- 智慧供应链管理解决方案-数字化供应链解决方案.docx
- 2023-2024成人健康管理洞察报告-益普索.docx
- 2024年中国人工智能系列白皮书-智能系统工程-中国人工智能学会.docx
- 房地产培训 -世联-万科双月湾口袋手册.docx
- 【智研咨询】民营医院行业现状分析、政策概览、发展环境及未来趋势预测.docx
最近下载
- 2024年徐州工业职业技术学院单招职业技能测试题库及答案(夺冠系列).docx VIP
- Module1 Unit 1 Saving the Earth教案 2023-2024学年牛津上海版英语九年级下册.docx
- [英语]英语音标.ppt
- 2022-2023年副主任医师(副高)-健康教育与健康促进(副高)考试题库5(含答案).docx VIP
- 催收服务方案内容范本.docx
- 12D101-5 110KV及以下电缆敷设.docx VIP
- 版式设计基础与实战全套完整教学课件.pptx
- 2024“降低非计划重返手术室再手术率”实施方案.pdf
- Molnupiravir-EIDD-2801-DataSheet-生命科学试剂-MedChemExpress.pdf
- 中国电子科技集团 笔试题.pdf
文档评论(0)