版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Dijkstra算法模型设计与实现一、Dijkstra算法概述Dijkstra算法是一种点对多点的集中式最短路径算法,即寻找网络中其他所有节点到目的节点的最短路径。Dijkstra算法通过对路径的长度进行迭代,从而计算出到达目的节点的最短路径。其基本思想是按照路径长度增加的顺序来寻找最短路径,显然有:到达目的节点的最短路径中最短的肯定是节点的最近节点所对应的单条链路,最短路径中下一个最短的肯定是节点的下一个最近的邻节点所对应的单条链路,或者是通过前面选定的节点的最短的由两条链路组成的的路径,依次类推。二、Dijkstra算法描述设每个节点标定的到达目的节点1的最短路径长度估计为,如果在迭代的过
2、程中,已变成一个确定的值,称节点为永久标定的节点,这些永久标定的节点的集合用表示。在算法的每一步中,在以外的节点中,必定是选择与目的节点1最近的节点加入到集合中。具体算法如下:1. 初始化,即,。(若,则)。2. 寻找下一个与目的节点最近的节点,即求使下式成立的。置。如果包括了所有的节点,则算法结束。 ,3. 更改标定值,即对所有的,置,返回第2步。三、Dijkstra算法实现根据Dijkstra算法描述编写程序进行实现,程序中采用邻接矩阵表示一个有向图,输入为该图的邻接矩阵以及目的节点,输出为图中各点的邻接关系,依照次邻接关系可得到到达目的节点的最短路径。程序用C语言编写,GCC环境编译,具
3、体代码见附录。四、运行结果及分析选择一具有7个节点的有向图进行实验,其各边权重及拓扑结构如下所示:图1 实验用图选取节点1为目的节点,运行程序:1. 输入表示该图的邻接矩阵,不相邻的节点间链路权值用-1表示,代表无穷大;2. 输入目的节点编号;3. 得到输出结果,如下图所示。输出结果图2 程序运行截图1将输出结果用图表示为:图3 到达目的节点1的最短路由更改目的节点,选取目的节点为节点5,重新运行程序,得到结果如下:目的节点更改为5图4 程序运行截图2输出结果用图表示为:图5 到达目的节点5的最短路由选择不同的目的节点,利用此程序均能得出正确的最短路径,证明了程序的正确性。达到了较好的效果。附
4、源代码:#include <stdio.h>#include <stdlib.h>#define N 7 /*节点个数*/int main() double eNN,dN; int v; /*目的节点*/ int i,j,min,x; long p=0;int pathN;/*节点从0开始计数*/for(i=0;i<N;i+) printf("Input the weights to node %dn",i+1);for(j=0;j<N;j+) scanf("%lf",&eij); /*不相邻节点间边权用负数表
5、示*/ if(eij<0)eij=32767; printf("Input destination noden"); scanf("%d",&v); /*输入目的节点*/ v-=1; /*初始化*/ for(i=0;i<N;i+) di=eiv;pathi=v; p|=1<<v; while(1) min=32767;for(j=0;j<N;j+) if(p&(1<<j)continue; if(min>dj) i=j;min=dj; p|=1<<i;if(p>=(1<<N)-1) break;for(j=0;j<N;j+) if(p&(1<<j)continue; min=32767; for(i=0;i<N;i+)if(min>di+eji) min=di+eji; x=i; if(dj>min) dj=min;pathj=x; printf("*result:*n"); for(i=0;i<
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二件压线式公座行业深度研究报告
- 中国全塑隔膜阀项目投资可行性研究报告
- 2025年下半年五指山市面向社会招聘市属国企业领导人员易考易错模拟试题(共500题)试卷后附参考答案
- 2025年下半年云南省昆明市石林县事业单位招聘12人(第二批)易考易错模拟试题(共500题)试卷后附参考答案
- 2025年搅拌机租赁合同范本
- 2025年下半年云南省交通运输厅所属事业单位招聘58人笔试易考易错模拟试题(共500题)试卷后附参考答案
- 2025年下半年云南曲靖市麒麟区所属事业单位招聘研究生20人易考易错模拟试题(共500题)试卷后附参考答案
- 中国电池接触片项目投资可行性研究报告
- 2025年下半年临沧市烟草专卖局(公司)人才增补招考易考易错模拟试题(共500题)试卷后附参考答案
- 中国环行同步输送机项目投资可行性研究报告
- 中国金属防腐产业市场发展动态及前景模式分析报告2025-2030年
- 《服务理念与技巧》课件
- 有限空间作业安全协议书范本
- 2025年1月山西、陕西、宁夏、青海普通高等学校招生考试适应性测试(八省联考)化学试题(含答案)
- 提高手术安全核查正确率PDCA医院改善项目申报书
- 2025年高考语文第二轮复习:章回小说(教师版)
- GB 4396-2024二氧化碳灭火剂
- 初中学校教学常规管理制度
- 处方权调剂权培训
- 《课堂管理方法与技巧》课件
- 学术道德与学术规范
评论
0/150
提交评论