Dijkstra算法模型设计与实现.doc

Dijkstra算法模型设计与实现.doc

ID:50975019

大小:489.50 KB

页数:6页

时间:2020-03-16

Dijkstra算法模型设计与实现.doc_第1页
Dijkstra算法模型设计与实现.doc_第2页
Dijkstra算法模型设计与实现.doc_第3页
Dijkstra算法模型设计与实现.doc_第4页
Dijkstra算法模型设计与实现.doc_第5页
资源描述:

《Dijkstra算法模型设计与实现.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、Dijkstra算法模型设计与实现一、Dijkstra算法概述Dijkstra算法是一种点对多点的集中式最短路径算法,即寻找网络中其他所有节点到目的节点的最短路径。Dijkstra算法通过对路径的长度进行迭代,从而计算出到达目的节点的最短路径。其基本思想是按照路径长度增加的顺序来寻找最短路径,显然有:到达目的节点的最短路径中最短的肯定是节点的最近节点所对应的单条链路,最短路径中下一个最短的肯定是节点的下一个最近的邻节点所对应的单条链路,或者是通过前面选定的节点的最短的由两条链路组成的的路径,依次类推。二、Dijk

2、stra算法描述设每个节点标定的到达目的节点1的最短路径长度估计为,如果在迭代的过程中,已变成一个确定的值,称节点为永久标定的节点,这些永久标定的节点的集合用表示。在算法的每一步中,在以外的节点中,必定是选择与目的节点1最近的节点加入到集合中。具体算法如下:1.初始化,即,,,。(若,则)。2.寻找下一个与目的节点最近的节点,即求使下式成立的。置。如果包括了所有的节点,则算法结束。,3.更改标定值,即对所有的,置,返回第2步。三、Dijkstra算法实现根据Dijkstra算法描述编写程序进行实现,程序中采用邻接

3、矩阵表示一个有向图,输入为该图的邻接矩阵以及目的节点,输出为图中各点的邻接关系,依照次邻接关系可得到到达目的节点的最短路径。程序用C语言编写,GCC环境编译,具体代码见附录。四、运行结果及分析选择一具有7个节点的有向图进行实验,其各边权重及拓扑结构如下所示:图1实验用图选取节点1为目的节点,运行程序:1.输入表示该图的邻接矩阵,不相邻的节点间链路权值用-1表示,代表无穷大;2.输入目的节点编号;3.得到输出结果,如下图所示。输出结果图2程序运行截图1将输出结果用图表示为:图3到达目的节点1的最短路由更改目的节点,

4、选取目的节点为节点5,重新运行程序,得到结果如下:目的节点更改为5图4程序运行截图2输出结果用图表示为:图5到达目的节点5的最短路由选择不同的目的节点,利用此程序均能得出正确的最短路径,证明了程序的正确性。达到了较好的效果。附源代码:#include#include#defineN7/*节点个数*/intmain(){doublee[N][N],d[N];intv;/*目的节点*/inti,j,min,x;longp=0;intpath[N];/*节点从0开始计数*/for(

5、i=0;i

6、=1<

7、ile(1){min=32767;for(j=0;jd[j]){i=j;min=d[j];}}p

8、=1<=(1<d[i]+e[j][i]){min=d[i]+e[j][i];x=i;}if(d[j]>min){d[j]=min;path[j]=x;}}}print

9、f("***result:***");for(i=0;iP%d",i+1,path[i]+1);}exit(EXIT_SUCCESS);}

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。