常州上位机培训

常州机器视觉培训

常州机器人培训

江苏和讯自动化设备有限公司欢迎您!
  • 和讯PLC,电工培训中心优势,名师团队一对一教学.
热门课程
联系方式
  • 常州和讯自动化培训中心
  • 常州市新北区太湖东路府琛大厦2号楼307-1室,307-2室(常州万达广场对面)
  • 电话:0519-85602926
  • 手机:15861139266 13401342299
当前位置:网站首页 > 新闻中心 新闻中心
Dijkstra 算法详解-常州机器视觉培训,常州工业机器人培训
日期:2024-1-19 15:59:07人气:  标签:常州机器视觉培训 常州工业机器人培训

Dijkstra 算法

Dijkstra 算法与BFS算法的区别就是 : 从容器中弹出接下来要访问的节点的规则不同


BFS 弹出: 层级最浅的原则,队列里最下方的元素


Dijkstra 弹出: 代价最小的节点g(n)


g(n) :表示的是从开始节点到当前n节点的代价累加


Dijkstra在扩展的时候,同时考虑从n节点扩展所有可扩展节点的代价g(),如果某个节点m的代价g(m)比g(n)要小,则更新当前代价为g(m)


Dijkstra的最优性保证:图运行的过程中,任何一个被扩展或者访问的节点,保证存储的代价g()值是从起点节点开始到当前节点的最小值

1.png

Dijkstra 算法 伪代码流程


维护一个优先级队列,存储所有被扩展的节点,且节点按g()值的大小自动按从小到大排列。


-优先级队列首先为空,以起始节点Xs进行初始化


-起始节点g(Xs)=0,并且初始化其它节点的代价为无穷大


-循环:

    1、如果队列是空的,返回false,跳出循环

    2、弹出优先级队列中代价最小的节点n

    3、标记节点n为被扩展节点

    4、如果节点n为目标节点,返回true,跳出循环

    5、找到n节点周围可以扩展的所以节点(没被扩展过)m

        6、进行判断 如果g(m)为无穷大(说明其它节点也没发现过m),

            7、则计算 真正的g(m)=g(n)+Cnm,然后将m节点加入到优先级队列中

        8、进行判断 如果g(m)不为无穷大,有值了(说明其它节点发现过m,m已经在优先级队列中)

            9、再次进行判断 如果之前发现m时计算的g(m)比g(n)+Cnm大的话

                10、更新g(m)=g(n)+Cnm。

    11、重复循环至步骤1


-结束循环

Dijkstra 算法步骤示例

2.png

以这个图将Dijkstra 算法运行的步骤进行一个示例:


1、首先初始化队列,将起始节点放入优先级队列中

3.png

2、弹出起始节点

4.png

3、扩展弹出节点周围的节点


起始节点S可以扩展到子节点d\e\p,并且计算各节点的g值

5.png

4、将扩展的节点加入到优先级队列中,并且进行排序

g(p)最小,放到队列最前面,也就是图中的最下面,然后是d,最后是e。

6.png

5、弹出最小的g值节点

也就是p节点

7.png

然后循环至步骤3,直至结束


Dijkstra算法的优劣分析


•优点:完备的(如果问题有解,一定能找到解);最优的(找到的解一定是最优的)


•缺点:没有目标终点方向的,只是比广度搜索多了一个代价值判断,如果每个边的代价都是1的话,那么就变成了广度搜索。


针对该缺点,与之对应的就是启发式搜索,例如贪心算法,根据到目标的进行一个启发式搜索。


如果Dijkstra的最优性与启发式搜索结合,使搜索具有方向性时,也就是 A*算法了。

本文网址:
下一篇:没有资料

相关信息:
版权所有 CopyRight 2006-2017 江苏和讯自动化设备有限公司 电话:0519-85602926 地址:常州市新北区太湖东路府琛大厦2号楼307-1室,307-2室
ICP备14016686号-2 技术支持:常州鹤翔网络
本站关键词:常州电工培训 常州电工证 常州变频器培训 常州触摸屏培训 网站地图 网站标签
在线与我们取得联系