最短路径问题-数学建模.ppt
《最短路径问题-数学建模.ppt》由会员分享,可在线阅读,更多相关《最短路径问题-数学建模.ppt(31页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、最短路径问题最短路径问题参考书:参考书:参考书:参考书:1.1.1.1.傅鹂傅鹂傅鹂傅鹂 龚劬龚劬龚劬龚劬 刘琼荪刘琼荪刘琼荪刘琼荪 何中市何中市何中市何中市 数学实验科学出版社数学实验科学出版社数学实验科学出版社数学实验科学出版社2.2.2.2.张绍民张绍民张绍民张绍民 李淑华李淑华李淑华李淑华 数据结构教程数据结构教程数据结构教程数据结构教程C C C C语言版中国电力出版社语言版中国电力出版社语言版中国电力出版社语言版中国电力出版社1主要内容主要内容Floyd算法Dijkstra算法两个例子的求解引例2:最廉价航费表的制定引例1:最短运输路线问题最短路径问题的0-1规划模型2如如如如图图
2、图图的的的的交交交交通通通通网网网网络络络络,每每每每条条条条弧弧弧弧上上上上的的的的数数数数字字字字代代代代表表表表车车车车辆辆辆辆在在在在该该该该路路路路段段段段行行行行驶驶驶驶所所所所需需需需的的的的时时时时间间间间,有有有有向向向向边边边边表表表表示示示示单单单单行行行行道道道道,无无无无向向向向边边边边表表表表示示示示可可可可双双双双向向向向行行行行驶驶驶驶。若若若若有有有有一一一一批批批批货货货货物物物物要要要要从从从从1 1 1 1号号号号顶顶顶顶点点点点运运运运往往往往11111111号号号号顶顶顶顶点点点点,问问问问运运运运货车应沿哪条线路行驶,才能最快地到达目的地?货车应沿
3、哪条线路行驶,才能最快地到达目的地?货车应沿哪条线路行驶,才能最快地到达目的地?货车应沿哪条线路行驶,才能最快地到达目的地?引例引例1 1:最短运输路线问题最短运输路线问题 10237411659813 35 512122 210106 61 15 58 88 87 79 99 93 32 22 27 73 某某某某公公公公司司司司在在在在六六六六个个个个城城城城市市市市C C C C1 1 1 1,C,C,C,C2 2 2 2,C,C,C,C3 3 3 3,C,C,C,C4 4 4 4,C,C,C,C5 5 5 5,C,C,C,C6 6 6 6都都都都有有有有分分分分公公公公司司司司,公公公
4、公司司司司成成成成员员员员经经经经常常常常往往往往来来来来于于于于它它它它们们们们之之之之间间间间,已已已已知知知知从从从从CiCiCiCi到到到到C C C Cj j j j的的的的直直直直达达达达航航航航班班班班票票票票价价价价由由由由下下下下述述述述矩矩矩矩阵阵阵阵的的的的第第第第i i行行行行,第第第第j j列列列列元元元元素素素素给给给给出出出出(表表表表示示示示无无无无直直直直达达达达航航航航班班班班),该该该该公公公公司司司司想想想想算算算算出出出出一一一一张张张张任任任任意意意意两两两两个个个个城城城城市市市市之之之之间间间间的的的的最最最最廉价路线航费表。廉价路线航费表。廉价
5、路线航费表。廉价路线航费表。引例引例2 2:最廉价航费表的制定最廉价航费表的制定 4最短路径问题l定义:设定义:设P(u,v)是加权图是加权图G中从中从u到到v的路径的路径,则该则该路径上的边权之和称为该路径的权路径上的边权之和称为该路径的权,记为记为w(P).从从u到到v的路径中权最小者的路径中权最小者 P*(u,v)称为称为u到到v的最短路径的最短路径.10237411659813 35 512122 210106 61 15 58 88 87 79 99 93 32 22 27 75最短路径算法DijkstraDijkstra算法算法算法算法使用范围使用范围使用范围使用范围:1)1)寻求
6、从一固定顶点到其余各点的最短路径寻求从一固定顶点到其余各点的最短路径寻求从一固定顶点到其余各点的最短路径寻求从一固定顶点到其余各点的最短路径;2)2)有向图、无向图和混合图有向图、无向图和混合图有向图、无向图和混合图有向图、无向图和混合图;3)3)权非负权非负权非负权非负.算法思路:算法思路:算法思路:算法思路:采用标号作业法采用标号作业法采用标号作业法采用标号作业法,每次迭代产生一个永久标号每次迭代产生一个永久标号每次迭代产生一个永久标号每次迭代产生一个永久标号,从而生长一颗以从而生长一颗以从而生长一颗以从而生长一颗以v v0 0为根的最短路树为根的最短路树为根的最短路树为根的最短路树,在这
7、颗树上每在这颗树上每在这颗树上每在这颗树上每个顶点与根节点之间的路径皆为最短路径个顶点与根节点之间的路径皆为最短路径个顶点与根节点之间的路径皆为最短路径个顶点与根节点之间的路径皆为最短路径.10237411659813 35 51 12 22 21 10 06 6 1 15 58 88 87 79 99 93 32 22 27 76Dijkstra算法算法算法步骤算法步骤S:具有永久标号的顶点集具有永久标号的顶点集;l(v):v的标记的标记;f(v):v的父顶点的父顶点,用以确定最短路径用以确定最短路径;输入加权图的带权邻接矩阵输入加权图的带权邻接矩阵w=w(vi,vj)nxm.1)初始化初始
8、化 令令l(v0)=0,S=;v v0,l(v)=;2)更新更新l(v),f(v)3)寻找不在寻找不在S中的顶点中的顶点u,使使l(u)为最小为最小.把把u加入到加入到S中中,然后对所有不在然后对所有不在S中的顶点中的顶点v,如如l(v)l(u)+w(u,v),则更新则更新l(v),f(v),即即 l(v)l(u)+w(u,v),f(v)u;3)重复步骤重复步骤2),直到所有顶点都在直到所有顶点都在S中为止中为止.7MATLAB程序(程序(Dijkstra算法)算法)function min,path=dijkstra(w,start,terminal)function min,path=di
9、jkstra(w,start,terminal)n=size(w,1);label(start)=0;f(start)=start;n=size(w,1);label(start)=0;f(start)=start;for i=1:nfor i=1:n if i=start if i=start label(i)=inf;label(i)=inf;end,endend,ends(1)=start;u=start;s(1)=start;u=start;while length(s)nwhile length(s)(label(u)+w(u,v)if label(v)(label(u)+w(u,v
10、)label(v)=(label(u)+w(u,v);f(v)=u;label(v)=(label(u)+w(u,v);f(v)=u;end,end,end end,end,end v1=0;v1=0;k=inf;k=inf;for i=1:n for i=1:n ins=0;ins=0;for j=1:length(s)for j=1:length(s)if i=s(j)if i=s(j)ins=1;ins=1;end,end end,end if ins=0 if ins=0 v=i;v=i;if klabel(v)if klabel(v)k=label(v);v1=v;k=label(v
11、);v1=v;end,end,end end,end,end s(length(s)+1)=v1;s(length(s)+1)=v1;u=v1;u=v1;endendmin=label(terminal);min=label(terminal);path(1)=terminal;path(1)=terminal;i=1;i=1;while path(i)=startwhile path(i)=start path(i+1)=f(path(i);path(i+1)=f(path(i);i=i+1;i=i+1;endend path(i)=start;path(i)=start;L=length(
12、path);L=length(path);path=path(L:-1:1);path=path(L:-1:1);8最短路径算法Dijkstra算法程序的使用说明:算法程序的使用说明:算法程序的使用说明:算法程序的使用说明:调用格式为调用格式为调用格式为调用格式为 min,path=dijkstra(w,start,terminal)min,path=dijkstra(w,start,terminal),其中输入变量其中输入变量其中输入变量其中输入变量w w为所求图的带权邻接矩阵,为所求图的带权邻接矩阵,为所求图的带权邻接矩阵,为所求图的带权邻接矩阵,start,start,terminalt
13、erminal分别为路径的起点和终点的号码。分别为路径的起点和终点的号码。分别为路径的起点和终点的号码。分别为路径的起点和终点的号码。返回返回返回返回startstart到到到到terminalterminal的最短路径的最短路径的最短路径的最短路径pathpath及其长度及其长度及其长度及其长度min.min.注意:顶点的编号从注意:顶点的编号从注意:顶点的编号从注意:顶点的编号从1 1开始连续编号。开始连续编号。开始连续编号。开始连续编号。9最短路径算法Floyd算法算法算法算法使用范围使用范围使用范围使用范围:1)1)求每对顶点的最短路径求每对顶点的最短路径求每对顶点的最短路径求每对顶点
14、的最短路径;2)2)有向图、无向图和混合图有向图、无向图和混合图有向图、无向图和混合图有向图、无向图和混合图;算法思想算法思想算法思想算法思想:直接在图的带权邻接矩阵中用插入顶点的方法依次直接在图的带权邻接矩阵中用插入顶点的方法依次直接在图的带权邻接矩阵中用插入顶点的方法依次直接在图的带权邻接矩阵中用插入顶点的方法依次递推地构造出递推地构造出递推地构造出递推地构造出n n个矩阵个矩阵个矩阵个矩阵D(1),D(2),D(n),D(n)D(1),D(2),D(n),D(n)是是是是图的距离矩阵图的距离矩阵图的距离矩阵图的距离矩阵,同时引入一个后继点矩阵记录两点同时引入一个后继点矩阵记录两点同时引入
15、一个后继点矩阵记录两点同时引入一个后继点矩阵记录两点间的最短路径间的最短路径间的最短路径间的最短路径.10237411659813 35 51 12 22 21 10 06 6 1 15 58 88 87 79 99 93 32 22 27 710Floyd算法算法算法步骤算法步骤 d(i,j):i到到j的距离的距离;path(i,j):i到到j的路径上的路径上i的后继点的后继点;输入带权邻接矩阵输入带权邻接矩阵a(i,j).1)赋初值)赋初值 对所有对所有i,j,d(i,j)a(i,j),path(i,j)j,k=l.2)更新)更新d(i,j),path(i,j)对所有对所有i,j,若若d(
16、i,k)+d(k,j)d(i,j),则则 d(i,j)d(i,k)+d(k,j),path(i,j)path(i,k),k k+13)重复)重复2)直到直到k=n+111MATLAB程序(程序(Floyd算法)算法)function D,path,min1,path1=floyd(a,start,terminal)function D,path,min1,path1=floyd(a,start,terminal)D=a;n=size(D,1);path=zeros(n,n);D=a;n=size(D,1);path=zeros(n,n);for i=1:nfor i=1:n for j=1:n
17、 for j=1:n if D(i,j)=inf if D(i,j)=inf path(i,j)=j;path(i,j)=j;end,end,endend,end,endfor k=1:nfor k=1:n for i=1:n for i=1:n for j=1:n for j=1:n if D(i,k)+D(k,j)D(i,j)if D(i,k)+D(k,j)D(i,j)D(i,j)=D(i,k)+D(k,j);D(i,j)=D(i,k)+D(k,j);path(i,j)=path(i,k);path(i,j)=path(i,k);end,end,end,endend,end,end,end
18、if nargin=3if nargin=3 min1=D(start,terminal);min1=D(start,terminal);m(1)=start;m(1)=start;i=1;i=1;path1=;path1=;while path(m(i),terminal)=terminal while path(m(i),terminal)=terminal k=i+1;k=i+1;m(k)=path(m(i),terminal);m(k)=path(m(i),terminal);i=i+1;i=i+1;end end m(i+1)=terminal;m(i+1)=terminal;pat
19、h1=m;path1=m;end end 12最短路径算法Floyd算法程序的使用说明:算法程序的使用说明:算法程序的使用说明:算法程序的使用说明:1.D,path=floyd(a),1.D,path=floyd(a),返回矩阵返回矩阵返回矩阵返回矩阵D,path D,path。其中。其中。其中。其中a a是所求是所求是所求是所求图的带权邻接矩阵,图的带权邻接矩阵,图的带权邻接矩阵,图的带权邻接矩阵,D(i,j)D(i,j)表示表示表示表示i i到到到到j j的最短距离的最短距离的最短距离的最短距离;path(i,j)path(i,j)表示表示表示表示i i与与与与j j之间的最短路径上顶点之
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 路径 问题 数学 建模
限制150内