Dijkstra算法例子

作者: 学习编程王同学 | 来源:发表于2019-05-11 11:25 被阅读0次

Dijkstra算法代码下载本文涉及到的代码。

程序代码

Dijkstra算法的程序如下:

function [d, p] = dijkstra(adj, s, t)
% 使用dijkstra求最短路径
% adj       输入  矩阵          邻接矩阵
% s         输入  整数          起点
% t         输入  整数 或 []    终点
% d         输出  向量          路径长度,若t==[],则返回从起点到所有节点的路径长度
% p         输出  向量 或 元胞   路径,若t==[],则返回从起点到所有节点的路径(cell)
nodes_num = size(adj, 1);
dist = inf(nodes_num, 1);
previous = inf(nodes_num, 1);
Q = [1:nodes_num]';

% 求邻居
neighbors = cell(nodes_num, 1);
for i = 1:nodes_num; neighbors{i} = find(adj(i, :) > 0); end

dist(s) = 0;
while ~isempty(Q)
    % 取出距离最小点
    [~, min_ind] = min(dist(Q));
    min_node = Q(min_ind);
    Q = setdiff(Q, min_node);
    
    % 若是终点,则结束程序
    if min_node == t
        d = dist(min_node);
        p = generate_path(previous, t);
        return;
    end
    
    % 更新邻居的距离
    for i = 1:length(neighbors{min_node})
        neighbor = neighbors{min_node}(i);
        alt = dist(min_node) + adj(min_node, neighbor);
        if alt < dist(neighbor)
            dist(neighbor) = alt;
            previous(neighbor) = min_node;
        end
    end 
end
d = dist;
p = cell(nodes_num, 1);
for i = 1:nodes_num; p{i} = generate_path(previous, i); end
end

% 由前趋推出路径
function path = generate_path(previous, t)
path = [t];
while previous(t) <= length(previous)
    path = [previous(t) path];
    t = previous(t);
end
end

找图中顶点间最短距离

无向拓扑图

在这样一张图中,找到从A到D的最短距离和路径。构造邻接矩阵如下:

adj = [
    0 12 0 0 0 16 14;
    12 0 10 0 0 7 0;
    0 10 0 3 5 6 0;
    0 0 3 0 4 0 0;
    0 0 5 4 0 2 8;
    16 7 6 0 2 0 9;
    14 0 0 0 8 9 0];

指定起点和终点,使用上面的程序计算即可:

[dist, path] = dijkstra(adj, 1, 4);

结果如下:

最短距离: 22.00
路径 :     'A'    'F'    'E'    'D'
无向拓扑图路径

找栅格地图中两点间最短距离

如下图所示栅格地图,指定起点和终点,智能体(或机器人)只能在“上、下、左、右”四个方向移动,找出最短路径:

栅格地图

结果如下:

栅格地图结果

可以直接提供邻接矩阵给上面的程序,但是需要修改程序中求邻居的部分(四个方向相邻栅格中不是障碍物的栅格),同时还需要在程序中对某栅格是否是障碍物进行判断,因为是障碍物的话程序不需要对该栅格进行规划。

也可以为程序提供栅格数量(除障碍物)和每个栅格的邻居,删除程序中求邻居的部分,修改程序中邻居间的距离(比如为1)即可。

相关文章

  • 算法导论系列:贪心算法(2)

    这篇文章我们将来一起看看贪心算法一个具体例子,Dijkstra算法 Dijkstra算法最著名的应用是解决单元最短...

  • Dijkstra算法例子

    在Dijkstra算法代码下载本文涉及到的代码。 程序代码 Dijkstra算法的程序如下: 找图中顶点间最短距离...

  • 图的最短路径

    Dijkstra算法&Floyd算法 一、Dijkstra算法 Dijkstra算法思想: 只计算v0出发到其他顶...

  • JavaScript模拟图操作

    JS操作实现无向网的Prim算法 最后输出结果如下: 其中例子中的图如下: JavaScript实现Dijkstra算法

  • 深入解析Dijkstra's Algorithm ——

    什么是Dijkstra算法? Dijkstra算法是用来寻找最短路径最著名的算法之一。具体来说,Dijkstra算...

  • Dijkstra 算法

    Dijkstra 算法 前言 为了达到任意两结点的最短路径,我们有几种算法可以实现:Dijkstra 算法、Flo...

  • 寻找最短路径

    这方面的经典算法,有Dijkstra算法和Floyd算法。 下面简单说一下基于Dijkstra算法略作小改动的一个...

  • 7.8图的应用:最短路径问题

    最短路径问题:Dijkstra算法 ❖解决带权最短路径问题的经典算法是以发明者命名的“Dijkstra算法”❖这是...

  • 最短路径

    两种最短路径算法:Dijkstra和Bellman 学习资料:《啊哈!算法》 Dijkstra 问题:在一张图中,...

  • 模板

    并查集 拓扑排序 Floyd算法 Dijkstra算法

网友评论

    本文标题:Dijkstra算法例子

    本文链接:https://www.haomeiwen.com/subject/cvqxaqtx.html