跳到主要内容
Z

A* 寻路算法可视化工具

在方格网格上交互式演示 A* 寻路算法,使用曼哈顿距离启发式函数——绘制墙壁障碍、拖动起点/终点、生成迷宫、逐步执行搜索过程。完全在浏览器中运行。

免费 无需注册 客户端运行 注重隐私 Updated

Move the indigo token with / WASD (or tap an adjacent cell) from the green start to the red goal. Walls block you.

Moves: Time: 🎉 Reached the goal!
/

伪代码

使用方法

  1. 1 按住鼠标拖动来绘制墙壁障碍;拖动绿色起点或红色终点即可改变位置。
  2. 2 点击 Play 观看 A* 借助距离启发式函数向目标推进的过程。
  3. 3 使用 Maze 立即生成障碍物,或使用 Step 逐个节点地执行搜索。
  4. 4 留意 A* 相比 Dijkstra 或 BFS 遍历的格子要少得多。

为什么使用此工具

  • 直观感受曼哈顿距离启发式函数如何引导搜索过程直奔目标。
  • A* 能找到最短路径,同时遍历的节点数远少于无信息搜索。
  • 可在本工具与 Dijkstra / BFS 可视化工具之间切换,对比不同的遍历方式。
  • 完全在你的浏览器中运行,无需注册,无需上传文件。

常见问题

什么是 A* 算法?

A*(读作 A-star)是一种最佳优先(best-first)寻路算法,它按照 f = g + h 对边界节点(frontier)排序,其中 g 是从起点出发的实际代价,h 是到目标点代价的启发式估计值。

这个工具使用的是哪种启发式函数?

曼哈顿距离(|Δrow| + |Δcol|),这是一种在四方向网格上可采纳(admissible)的启发式函数——它永远不会高估实际代价,因此 A* 始终能保证找到最短路径。

A* 算法的时间复杂度是多少?

最坏情况下与 Dijkstra 相同,为 O(E log V),但在有良好启发式函数的情况下,实际遍历的节点数会少得多。

A* 在什么情况下优于 Dijkstra?

只要你有一个明确的单一目标点以及一个有效的启发式函数,A* 就更有优势。A* 会集中朝目标方向搜索,而 Dijkstra 则会向各个方向均匀扩展。

什么是 A* 寻路算法可视化工具?

A* 寻路算法可视化工具动态演示了 A* 搜索算法在方格网格上的运行过程。A* 按照 f = g + h(已走过的代价加上曼哈顿距离启发式估计值)对边界节点(frontier)进行排序,从而使搜索过程朝目标方向推进,在比无信息搜索算法(uninformed search)遍历少得多的格子的情况下,找到最短路径。

概要

A* 寻路算法可视化工具 是 Zerethon Tools 提供的免费 算法 工具。在方格网格上交互式演示 A* 寻路算法,使用曼哈顿距离启发式函数——绘制墙壁障碍、拖动起点/终点、生成迷宫、逐步执行搜索过程。完全在浏览器中运行。. 完全在浏览器中运行 — 无需注册,无需上传。

分类
算法
价格
免费
隐私
基于浏览器
注册
无需

隐私

除非另有说明,否则你的数据永远不会离开浏览器。A* 寻路算法可视化工具 完全在客户端运行 — 无需上传服务器,不记录日志,不追踪你输入的内容。

刚接触?阅读包含 Big-O 分析的分步讲解: 了解 Graph Algorithms →

对比

相关工具

在 Zerethon Social 上创作、分享与成长

免费注册。赚取积分,收集成就,与全球创作者建立联系。

免费注册