图论在实际生活中应用.docVIP

  • 34
  • 0
  • 约5.62千字
  • 约 11页
  • 2017-06-09 发布于北京
  • 举报
摘 要 寻找最短的路径到达想要去的地方在这个快节奏的时代已经变得越来越重要,它对于节约人们的时间成本具有重要意义。当前城市的规模越来越大,交通道路状况也越来越复杂,从一个地方到另一个地方可能有很多种路径,如何从众多的路径中选择距离最短或者所需时间最短的路径便成了人们关注的热点。能够选择出一条最符合条件的路径会给我们的日常生活带来极大地方便。本文就通过找重庆邮电大学几个代表性地点之间寻找最短距离路径为例,介绍经典的最短路径算法Floyd算法及其算法的实现。 关键字: 最优路径,Floyd算法,寻路 一、图论的基本知识 图论起源于的柯尼斯堡七桥问题。在柯尼斯堡的普莱格尔河上有七座桥将河中的岛及岛与河岸起来问题是要从这四块陆地中任何一块开始,通过每一座桥正好一次,再回到起点。然而无数次的尝试都没有成功。在1736年欧拉解决了这个问题,他用抽像分析法将这个问题化为第一个图论问题:即用点来代替每一块陆地,将每一座桥用联接相应的两个点的一条线来代替,相当于得到一个“图”(如下图)。柯尼斯堡七桥 欧拉证明了这个问题没有解,并且推广了这个问题,给出了对于一个给定的图可以某种方式走遍的判定法则。这项工作使成为图论〔及〕的创始人。 图论〔Graph Theory〕是数学的一个分支它图论中的是由若干给定的点及连接两点的线所构成的图形,这种图形通常用来描述某些事物之间的某种特定关系,用点代表事物,用连接两点的线表示相应两个事物间具有这种关系。 为无向标定图,中顶点与边的交替序列 称为到的通路,其中,为的端点,分别称为始点与终点,中的边的条数称为它的长度,若又有,则称为回路。若的所有边各异,则称为简单通路。若又有,则称为简单回路,若所有的顶点(除与可能相同外)各异,所有的边也各异,则称为初级通路或路径,若又有,则为初级回路或圈,将长度为奇数的圈成为奇圈,长度为偶数的圈为偶圈。 我们要考虑的问题是对任意给定的一个赋权图,及中两个指点的顶点与,求出其最短路径。易见。只要考虑简单连通图的情形就够了。这里我们假设每边的权都是大于0的实数。因为当一条边的权为0时。我们可以把和合并成一个顶点。又,我们约定边当且仅当。 1.3 Floyd算法 ? Floyd算法的基本思想: ??? 可以将问题分解,先找出最短的距离,然后在考虑如何找出对应的行进路线。如何找出最短路径呢,这里还是用到动态规划的知识,对于任何一个地点而言,i到j的最短距离不外乎存在经过i与j之间的k和不经过k两种可能,所以可以令k=1,2,3,...,n(n是地点的数目),在检查d(ij)与d(ik)+d(kj)的值;在此d(ik)与d(kj)分别是目前为止所知道的i到k与k到j的最短距离,因此d(ik)+d(kj)就是i到j经过k的最短距离。所以,若有d(ij)d(ik)+d(kj),就表示从i出发经过k再到j的距离要比原来的i到j距离短,自然把i到j的d(ij)重写为d(ik)+d(kj),每当一个k查完了,d(ij)就是目前的i到j的最短距离。重复这一过程,最后当查完所有的k时,d(ij)里面存放的就是i到j之间的最短距离了。 ??? Floyd算法的基本步骤: ??? 定义n×n的方阵序列D-1, D0 , … Dn-1, 初始化: D-1=C ??? D-1[i][j]=边i,j的长度,表示初始的从i到j的最短路径长度,即它是从i到j的中间不经过其他中间点的最短路径。 迭代:设Dk-1已求出,如何得到Dk(0≤k≤n-1) ??? Dk-1[i][j]表示从i到j的中间点不大于k-1的最短路径p:i…j, ??? 考虑将顶点k加入路径p得到顶点序列q:i…k…j, ??? 若q不是路径,则当前的最短路径仍是上一步结果:Dk[i][j]= Dk-1[i][j]; ??? 否则若q的长度小于p的长度,则用q取代p作为从i到j的最短路径。 ??? 因为q的两条子路径i…k和k…j皆是中间点不大于k-1的最短路径,所以从i到j中间点不大于k的最短路径长度为: Dk[i][j]=min{ Dk-1[i][j], Dk-1[i][k] +Dk-1[k][j] } 利用图论知识寻找指定两点最短路径 2.1 把实际问题转化成图论问题 图1 重庆邮电大学地图 上图为邮电大学的地图,我们在地图中选取重邮的八个地方看成是八个点(1、新世纪超市 2、三教学楼 3、数字图书馆 4、二教学楼 5、信科大楼 6、太极操场 7、老图书馆 8、31栋宿舍),用线

文档评论(0)

1亿VIP精品文档

相关文档