为什么A*搜索算法比A搜索算法更好?

我试图理解为什么从理论上讲,A*搜索算法被认为比A搜索算法更好。

在这两种算法中,节点都是根据函数f(n)来展开的。

A中:f(n) = g(n) + h(n)

A*中:f(n) = g(n) + h*(n)(*表示该函数是一个估计值)。

A*应该能减少需要生成和比较的路径数量。我的问题是:使用h*(n)代替h(n)是如何减少路径数量的?

谢谢 🙂


回答:

因为你通常不知道h(n)的准确值。要计算这个值,你必须从那个节点开始进行一次完整的搜索到目标节点,而对每个节点都这样做将非常耗费资源。


考虑城市之间由道路连接的情况。你如何知道从任何一个城市到达目标城市的旅行距离是多少?没有进行搜索你是无法知道的。相反,你可以例如使用直接距离作为实际旅行距离的估计值,如果你有两个城市的坐标,这是一个非常简单且快速的计算方法。

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注