gpt4 book ai didi

algorithm - 在 A* 搜索算法中,您在遍历打开列表时检查什么?

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:52:15 24 4
gpt4 key购买 nike

我对存储第一个节点后下一步要做什么感到有点困惑。在wikipedia page about A*它说要忽略已经在封闭集中的邻居,但如果它不存在,则将其添加到开放集中(如果它不存在)并检查 g 分数。

但是在这个页面上https://brilliant.org/wiki/a-star-search/ ,它说检查“邻居的 g 值是否低于当前并且在封闭列表中”然后替换邻居的 g 值否则如果“当前 g 值较低并且这个邻居在开放列表中”“然后替换邻居有了新的、更低的 g 值"

所以我对要检查的内容有点困惑。如果节点已经在封闭集中,我是忽略它还是我还需要检查它的 g 值并用它替换邻居的值?

在我拥有 A* 中的第一个节点后我该做什么?

最佳答案

如果我们找到一个在封闭集中的邻居,这意味着我们之前已经访问过它。这意味着以下两件事之一:

  1. 它的 g 分数已经很小,所以永远不会执行 Brilliant 上的额外条件。

  2. 启发式函数 h Not Acceptable ,即它高估了实现目标的实际最小成本。在这种情况下,Brilliant 上的代码可能会找到稍短的路径,但都不能保证找到最短的路径。要使用不允许的启发式方法找到最短路径,您需要“重新打开”此类节点。这将导致算法多次重新访问整个子图,这将严重损害复杂性,这不是 Brilliant 代码正在做的事情。

总结一下:Brilliant 和维基百科版本之间的区别在于处理一个小的极端情况,如果 A* 被赋予“正确”(可接受的)启发式函数,这种情况就不会发生。

So I'm sort of confused on what to check for. Do I ignore the node if it's already in the closed set or do I need to also check it's g value and replace the neighbor's with it?

我会遵循维基百科代码并完全忽略封闭集中的节点。

关于algorithm - 在 A* 搜索算法中,您在遍历打开列表时检查什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55985654/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com