码迷,mamicode.com
首页 > 编程语言 > 详细

Dijkstra算法,Floyd算法以及A*算法

时间:2014-12-15 06:29:34      阅读:543      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   ar   使用   sp   strong   on   2014   

Dijkstra算法

Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径。主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。

 

Floyd算法

Floyd算法是一个经典的动态规划算法。用通俗的语言来描述的话,首先我们的目标是寻找从点i到点j的最短路径。从动态规划的角度看问题,我们需要为这个目标重新做一个诠释(这个诠释正是动态规划最富创造力的精华所在)

从任意节点i到任意节点j的最短路径不外乎2种可能,1是直接从i到j,2是从i经过若干个节点k到j。所以,我们假设Dis(i,j)为节点u到节点v的最短路径的距离,对于每一个节点k,我们检查Dis(i,k) + Dis(k,j) < Dis(i,j)是否成立,如果成立,证明从i到k再到j的路径比i直接到j的路径短,我们便设置Dis(i,j) = Dis(i,k) + Dis(k,j),这样一来,当我们遍历完所有节点k,Dis(i,j)中记录的便是i到j的最短路径的距离。

 

A*算法

路径评分

选择路径中经过哪个方格的关键是下面这个等式:  

F = G + H                             

这里:
    * G = 从起点A,沿着产生的路径,移动到网格上指定方格的移动耗费。上下左右走是10,斜对角走是14,基本合比例。
    * H = 从网格上那个方格移动到终点B的预估移动耗费。H值可以用不同的方法估算。我们这里使用的方法被称为曼哈顿方法,它计算从当前格到目的格之间水平和垂直的方格的数量总和,忽略对角线方向。

 F被打印在左上角,G在左下角,H则在右下角。

bubuko.com,布布扣

 

Dijkstra算法,Floyd算法以及A*算法

标签:style   blog   http   ar   使用   sp   strong   on   2014   

原文地址:http://www.cnblogs.com/chenbuer/p/4164056.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!