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

【数学建模】-- Matlab中图的最短路径

前言:

 

图的基本概念:

若想简单绘制图可以利用此网站:

左上角Undirected/Directed是无向图/有向图  

左边 0-index ,1-index为0下标,1下标。

Node Count为节点个数

Graph Data:最初尾节点的名称(一个数据)

          相连两节点的名称与两节点连线的权重(三个数据)

利用matlab制作 “图”:

Graph中的s,t指的图中顶点的名称,而且元素数量必须相同,s和t对应位置的数据会在构中相连。

注意事项:

  1. 在结点名称中若我们使用的是字符串,需要用大括号{},中间的字符名称需要用 ‘’引起。

2.若结点名为常数,这些结点必须都是从1开始的正整数。

Graph中的第三个元素为权重,权重对应的则是节点之间相连的线。

Matlab中的有向图:

函数为:digraph()

无向图的权重邻接矩阵:

有向图的权重邻接矩阵:

求最小路径的算法:迪杰斯特拉算法:

博主之前在学习数据结构的时候创作过一篇关于迪杰斯特拉的文章:数据结构 -最短路径dijkstra(迪杰斯特拉)算法讲解及代码实现_地杰斯特拉_Wei&Yan的博客-CSDN博客可以参考里面的内容。

迪杰斯特拉的缺点:

如何修复该缺点:

什么是负权回路?

(注意无向图中的一条负权边也属于负权回路,如下图中结点3与结点2之间权重为-2的回路。)

在matlab中有计算最短路径的函数:

Shortserpath(图名称,起始节点,终点结点)

 

在图中高亮出图的最短路径

Highlight(plot的变量名,shortestpath中接受的P,‘EdgeColor’,‘颜色’)

返回任意两点的距离矩阵

找给定范围内所有的点:

课后作业:

只需要找出最短路径和长度即可。(最好可以将最短路径)    

参考代码: 

%创建图的顶点和边
s = {'v1','v1','v1','v2','v3','v3','v4','v5','v5','v5','v5','v6','v6','v7','v9','v9'};
t = {'v4','v2','v3','v5','v4','v2','v6','v4','v6','v7','v8','v5','v7','v8','v5','v8'};
w = [1,6,3,1,2,2,10,6,4,3,6,10,2,4,2,3];
G = digraph(s,t,w);
myplot = plot(G,'EdgeLabel',G.Edges.Weight,'LineWidth',2);%求出最短路径
[P,d] = shortestpath (G,'v1','v8')
highlight (myplot,P,'EdgeColor','red')

博主曾经也写过一篇关于数据结构图的博客 :图的基本概念和术语_Wei&Yan的博客-CSDN博客

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

相关文章:

  • 中国月入过万的人多不多
  • 苹果电脑图像元数据编辑器:MetaImage for Mac
  • BeanUtils.copyProperties() 详解
  • 基于CentOS 7构建LVS-DR集群
  • openEuler-OECA考试报名火热开启,尊享半价优惠 作者:HopeInfra 发布时间:2023-08-10
  • 侯捷 C++面向对象编程笔记——10 继承与虚函数
  • mysql日期函数(查询最近n(天/月/年)、计算日期之间的天数等)
  • 通过anvt X6和vue3实现图编辑
  • win2012 IIS8.5 安装PHP教程,一些版本不能用
  • sqlalchemy执行原生sql
  • Python-OpenCV中的图像处理-图像平滑
  • Mongoose http server 例子
  • 1、初识HTML
  • 线性代数(三) 线性方程组
  • Apoll 多项式规划求解
  • ssm亚盛汽车配件销售业绩管理统源码和论文PPT
  • 发布属于自己的 npm 包
  • Redis主从复制和哨兵架构图,集成Spring Boot项目实战分享
  • java中try-with-resources自动关闭io流
  • Games101学习笔记 -光栅化
  • Pytorch量化之Post Train Static Quantization(训练后静态量化)
  • Sql奇技淫巧之EXIST实现分层过滤
  • Linux下升级jdk1.8小版本
  • 【Mysql】数据库基础与基本操作
  • 87 | Python人工智能篇 —— 机器学习算法 决策树
  • 【计算机视觉】干货分享:Segmentation model PyTorch(快速搭建图像分割网络)
  • 解析湖仓一体的支撑技术及实践路径
  • 40.利用欧拉法求解微分方程组(matlab程序)
  • OpenAI-Translator 实战总结
  • 【工业机器人】用于轨迹规划和执行器分析的机械手和移动机器人模型(MatlabSimulink)