基于MATLAB求解最短路问题.doc_第1页
基于MATLAB求解最短路问题.doc_第2页
基于MATLAB求解最短路问题.doc_第3页
基于MATLAB求解最短路问题.doc_第4页
基于MATLAB求解最短路问题.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

基于MATLAB求解最短路问题1.引言 MATLAB和Mathematica、Maple并称为三大数学软件。它在数学类科技应用软件中在数值计算方面首屈一指。通过本学期的学习了解和上机实践,已经初步掌握使用MATLAB工具解决实际问题的能力。结合运筹学课程的学习,我考虑使用MATLAB求解最短路问题,而在所有求解最短路的方法中,Dijkstra算法是最为经典的一种,因此本文主要解决在MATLAB环境下使用Dijkstra算法求解最短路。1.1 提出问题设6个城市v1,v2,.,v6之间的一个公路网(图1)每条公路为图中的边,边上的权数表示该段公路的长度(单位:百公里),设你处在城市v1,那么从v1到v6应选择哪一路径使你的费用最省。 1.2 分析问题 这属于一个典型的求解最短路的问题,图中顶点代表六个城市,边上的权数表示该段公路的长度,题目所求为从v1到v6、的一条费用最省的路径,我们假设所需费用仅与路径长短有关,因此求费用最省的路径即求权值最小的路径。网络图中各权值均为正,可以使用Dijkstra算法。 1.3 数据整理 将网络图中各边的权作如下整理以方便程序运行 W(1,2)=5; W(2,1)=5; W(1,3)=2; W(3,1)=2; W(2,3)=1; W(3,2)=1; W(2,4)=5; W(4,2)=5; W(2,5)=5; W(5,2)=5; W(3,4)=8; W(4,3)=8; W(3,5)=10; W(5,3)=10; W(4,5)=2; W(5,4)=2; W(4,6)=5; W(6,4)=5; W(5,6)=2; W(6,5)=2;2.数学原理 2.1 Dijkstra算法介绍Dijkstra 算法思想为:设G=(V,E)是一个带权有向图(也可以是无向图,无向图是有向图的特例), 把图中顶点集合V分成两组:第一组为已求出最短路径的顶点集合(用S 表示,初始时S 中只有一个源点,以后每求得一条最短路径,就将其加入到集合S 中,直到全部顶点都加入到S 中,算法就结束了);第二组为其余未确定最短路径的顶点集合( 用U 表示), 按最短路径长度的递增次序依次把第二组的顶点加入S 中。在加入的过程中,总保持从源点v 到S 中各顶点的最短路径长度不大于从源点v 到U 中任何顶点的最短路径长度。此外,每个顶点对应一个距离,S 中的顶点的距离就是从v 到此顶点的最短路径长度,U中的顶点的距离,是从v 到此顶点只包括S 中的顶点为中间顶点的当前最短路径长度。其步骤主要有:第一,初始时,S 只包含源点,即S顶点,v 的距离为0。U 包含除v 外的其他顶点,U 中顶点u 距离为边上的权(若v 与u 有边)或(若u 不是v 的出边邻接点)。第二,从U 中选取一个距离v 最小的顶点k,把k 加入S 中(该选定的距离就是v 到k 的最短路径长度)。第三,以k 为新考虑的中间点,修改U 中各顶点的距离; 若从源点v 到顶点u的距离(经过顶点k)比原来距离(不经过顶点k)短,则修改顶点u 的距离值,修改后的距离值的顶点k 的距离加上边上的权。第四,重复步骤第二步和第三步直到所有顶点都包含在S 中。3. 程序设计function c0,c,path0,path=dijkstra(s,t,C,flag)s=floor(s);t=floor(t);n=size(C,1);label=ones(1,n)*inf;label(s)=0;S=s;Sbar=1:s-1,s+1:n;c0=0;path=zeros(n,n);path(:,1)=s;c=ones(1,n)*inf;parent=zeros(1,n);i=1; % number of points in point set S.while i label(S(k)+C(S(k),Sbar(j) label(Sbar(j)=label(S(k)+C(S(k),Sbar(j); parent(Sbar(j)=S(k); end end end % Find the minmal label(j), j in Sbar. temp=label(Sbar(1); son=1; for j=2:n-i if label(Sbar(j)V3-V2-V5-V6,结合网络图进行验证,所求即为最短路。并且利用上述程序还可求得网络中任意两点之间的最短路径。5. 学习体会 MATLAB是美国MathWorks公司出品的商业数学软件,用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境,主要包括MATLAB和Simulink两大部分。MATLAB是matrix&laboratory两个词的组合,意为矩阵工厂(矩阵实验室)。是由美国mathworks公司发布的主要面对科学计算、可视化以及交互式程序设计的高科技计算环境。它将数值分析、矩阵计算、科学数据可视化以及非线性动态系统的建模和仿真等诸多强大功能集成在一个易于使用的视窗环境中,为科学研究、工程设计以及必须进行有效数值计算的众多科学领域提供了一种全面的解决方案,并在很大程度上摆脱了传统非交互式程序设计语言(如C、Fortran)的编辑模式,代表了当今国际科学计算软件的先进水平。Matlab的学习是在运筹学之后开始的,虽然是作为选修课,也只安排了短短的10次课,但从一开始学习,我就抱着要掌握好这个工具的态度上课,因为不管是数学建模还是运筹学中,都可以用到它解决很多实际问题。课堂上教员给我们讲解了软件的基本操作并介绍了大量常用的命令,通过理论学习和上机实践操作,慢慢的从开始的完全不懂渐渐能够编写一些简单的M文件解决一些应用题,其中的成就感是相当令人欣慰的。虽然在此之前我们还学过C语言、C+和数据库,也可以用它们来编程解题,但相比之下,使用MATLAB要简单得多,同样的一个问题,用编程的方法可能需要编写很多条代码,在这个软件中却可以轻松实现。“师傅领进门,修行靠个人”,受限于开课课时,教员不可能给我们做太过深入的教学,因此要想学好这个软件,最重要的还是靠自己课下的探索,任何工具性的东西都是这样,只有练熟才了生巧。 对提高matlab编程能力的方法,我想主要有以下三个: 1、查help 在第一节课教员就向我们介绍了help命令,在学习过程中,时常遇到一些不知道的关键字,这时候只要通过help命令就可以找到该关键字的介绍,并且还有部分举例,非常有助于理解程序。 2、多上论坛,搜索帖子、发帖询问 网上有很多关于MATLAB的贴吧和论坛,许多学习这个程序的人都在这里交流,有初学者也有高手,上论坛的一个好处就是可以知道别人在学习过程中都遇到了一些什么问题,他们是怎么解决的,有什么好的学习经验和方法可以供自己借鉴,甚至也可以自己发帖和别人交流,请教高手解答自己的困惑等等。 3、阅读别人、特别是牛人的程序 多阅读程序永远是编程类软件学习的必经途径,只有通过多阅读,才能理解算法的思想,熟悉代码的编写方法。当然了,正如所有的程序语言一样,“3分课本7分上机”,一定要动手才行,不

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论