左上角Undirected/Directed是无向图/有向图
左边 0-index ,1-index为0下标,1下标。
Node Count为节点个数
Graph Data:最初尾节点的名称(一个数据)
利用matlab制作 “图”:
Graph中的s,t指的图中顶点的名称,而且元素数量必须相同,s和t对应位置的数据会在构中相连。
注意事项:
Graph中的第三个元素为权重,权重对应的则是节点之间相连的线。
Matlab中的有向图:
求最小路径的算法:迪杰斯特拉算法:
博主之前在学习数据结构的时候创作过一篇关于迪杰斯特拉的文章:数据结构 -最短路径dijkstra(迪杰斯特拉)算法讲解及代码实现_地杰斯特拉_Wei&Yan的博客-CSDN博客可以参考里面的内容。
什么是负权回路?
(注意无向图中的一条负权边也属于负权回路,如下图中结点3与结点2之间权重为-2的回路。)
在matlab中有计算最短路径的函数:
在图中高亮出图的最短路径
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博客