当前位置: 首页 > news >正文

图论——Dijkstra算法matlab代码

Dijkstra算法步骤
(1)构造邻接矩阵
(2)定义起始点
(3)运行代码

M=[  0     5     9   Inf   Inf   Inf   InfInf     0   Inf   Inf    12   Inf   InfInf     3     0    15   Inf    23   InfInf     6   Inf     0   Inf     8     7Inf    12   Inf     5     0   Inf    14Inf   Inf   Inf   Inf   Inf     0    10Inf   Inf   Inf   Inf   Inf   Inf     0];
first=2;
last=4;
[m,n]=size(M);
L=zeros(1,m);
symbol=zeros(1,m);
direction=zeros(1,m);
for i=1:mif(i~=first)L(i)=inf;enddirection(i)=first;
end
judge=1;
while judge
for i=1:mif(symbol(i)==0)min=L(i);temporary=i;breakend
end
for i=1:mif(symbol(i)==0)if(L(i)<min)min=L(i);temporary=i;endend
end
k=temporary;
for j=1:mif(symbol(1,j)==0)if(M(k,j)==inf)continue;elseif(L(k)+M(k,j)<L(j))L(j)=L(k)+M(k,j);direction(j)=k;endendend
end
symbol(k)=1;
num=0;
for i=1:mif(symbol(i)==1)num=num+1;end
end
if(num==m)judge=0;
end
end
p=last;
arrow=zeros(1,m);
arrow(1)=last;
i=2;
while p~=firstarrow(1,i)=direction(p);i=i+1;p=direction(p);
end
distance=L(last);

http://www.lryc.cn/news/228293.html

相关文章:

  • [MySQL] MySQL表的基础操作
  • SQL 部分解释。
  • 利用LangChain实现RAG
  • 零基础学习Matlab,适合入门级新手,了解Matlab
  • CCF ChinaSoft 2023 论坛巡礼 | 自动驾驶仿真测试论坛
  • vue封装useWatch hook支持停止监听和重启监听功能
  • 智能配方颗粒管理系统解决方案,专业实现中医药产业数字化-亿发
  • PXI总线测试模块-6951E 信号分析仪
  • 精确杂草控制植物检测模型的改进推广
  • C++:对象成员方法的使用
  • 深入了解SpringMvc接收数据
  • 华东“启明”青少年音乐艺术实践中心揭幕暨中国“启明”巴洛克合奏团首演音乐会
  • 17. 机器学习——SVM
  • 算法导论笔记5:贪心算法
  • Vue的高级表格组件库【vxe-table】
  • 从0到0.01入门React | 002.精选 React 面试题
  • 假冒 Skype 应用程序网络钓鱼分析
  • 软件外包开发的需求表达方法
  • 详解JS的四种异步解决方案:回调函数、Promise、Generator、async/await
  • Python进行多线程爬取数据通用模板
  • 基于springboot实现沁园健身房预约管理系统【项目源码】
  • 论文笔记:Deep Trajectory Recovery with Fine-Grained Calibration using Kalman Filter
  • ubuntu下tensorrt环境配置
  • 网络安全基础之php开发文件下载的实现
  • 【学习笔记】 - GIT的基本操作,IDEA接入GIT以及上传hub
  • Antd React Form.Item内部是自定义组件怎么自定义返回值
  • 2023最新ACL大模型论文分类汇总(有代码的)
  • Java版 招投标系统简介 招投标系统源码 java招投标系统 招投标系统功能设计
  • Ubuntu 22.04源码安装cmake 3.27.7
  • 无人地磅称重系统|自助过磅 料仓联动 自助卸料