- 40
- 0
- 约8.17千字
- 约 30页
- 2023-04-29 发布于湖北
- 举报
最短路径问题-数学建模
主要内容Floyd算法Dijkstra算法两个例子得求解引例2:最廉价航费表得制定引例1:最短运输路线问题最短路径问题得0-1规划模型
3如图得交通网络,每条弧上得数字代表车辆在该路段行驶所需得时间,有向边表示单行道,无向边表示可双向行驶。若有一批货物要从1号顶点运往11号顶点,问运货车应沿哪条线路行驶,才能最快地到达目得地? 引例1:最短运输路线问题 10237411659813512210615887993227
4 某公司在六个城市C1,C2,C3,C4,C5,C6都有分公司,公司成员经常往来于它们之间,已知从Ci到Cj得直达航班票价由下述矩阵得第i行,第j列元素给出(?表示无直达航班),该公司想算出一张任意两个城市之间得最廉价路线航费表。 引例2:最廉价航费表得制定
5最短路径问题定义:设P(u,v)就是加权图G中从u到v得路径,则该路径上得边权之与称为该路径得权,记为w(P)、 从u到v得路径中权最小者 P*(u,v)称为u到v得最短路径、10237411659813512210615887993227
最短路径算法Dijkstra算法使用范围:寻求从一固定顶点到其余各点得最短路径;有向图、无向图与混合图;权非负、算法思路: 采用标号作业法,每次迭代产生一个永久标号, 从而生长一颗以v0为根得最短路树,在这颗树上每个顶点与根节点之间得路径皆为最短路径、10237411659813512210615887993227
Dijkstra算法——算法步骤S: 具有永久标号得顶点集;l(v): v得标记; f(v):v得父顶点,用以确定最短路径; 输入加权图得带权邻接矩阵w=[w(vi,vj)]nxm、初始化 令l(v0)=0,S=?;? v?v0 ,l(v)=?;更新l(v), f(v) 寻找不在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;重复步骤2), 直到所有顶点都在S中为止、
MATLAB程序(Dijkstra算法)function [min,path]=dijkstra(w,start,terminal)n=size(w,1); label(start)=0; f(start)=start;for i=1:n if i~=start label(i)=inf;end, ends(1)=start; u=start;while length(s)n for i=1:n ins=0; for j=1:length(s) if i==s(j) ins=1; end, end if ins==0 v=i; if label(v)(label(u)+w(u,v)) label(v)=(label(u)+w(u,v)); f(v)=u; end, end, end v1=0; k=inf; for i=1:n ins=0; for j=1:length(s) if i==s(j) ins=1; end, end if ins==0 v=i; if klabel(v) k=label(v); v1=v; end, end, end s(length(s)+1)=v1; u=v1;endmin=label(terminal); path(1)=terminal;i=1; while path(i)~=start path(i+1)=f(path(i)); i=i+1 ;end path(i)=start;L=length(path);path=path(L:-1:1);①②③
9最短路径算法Dijkstra算法程序得使用说明: 调用格式为 [min,path]=dijkstra(w,start,terminal), 其中输入变量w为所求图得带权邻接矩阵,start, terminal分别为路径得起点与终点得号码。返回start到terminal得最短路径path及其长度min、注意:顶点得编号从1开始连续编号。
最短路径算法Floyd算法使用范围:求每对顶点得最
原创力文档

文档评论(0)