社区
数据结构与算法
帖子详情
A*算法能不能保证得到最优解?
NewStarSE
2005-06-25 10:59:43
我在陆汝今(钅今)的书上看到的结论是说保证能得到最优解。但蔡自兴的书上说是不能保证得到最优解。
到底谁对?
...全文
4899
21
打赏
收藏
A*算法能不能保证得到最优解?
我在陆汝今(钅今)的书上看到的结论是说保证能得到最优解。但蔡自兴的书上说是不能保证得到最优解。 到底谁对?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
21 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
熊主任
2005-07-26
打赏
举报
回复
看西交那本人工智能证明a*算法能求出最优解地证明时,必须注意有一个假设前提,那就是估价函数是最优的。所以我认为可以这么理解,如果用这个算法在合理的时间内找到合理的解,它就是a*算法,反之就不是。
ZeroGts
2005-07-25
打赏
举报
回复
1
蔡、傅是这么说的:算法要是可采用的,需要满足4个充分条件,除了前面提到的3个条件,还有一个:在目标节点处,需要f(n)≡f*(n),而A*算法并没有这一限制,所以不能保证得到最优解。
由
1、估值函数:f(n)=g(n)+h(n)
3、h(x)≤h*(x),对于任意的节点x都成立
可知在目标节点处有h(x)≤h*(x)=0,h(x)=0,f(n)=g(n)+0=f*(n)。所以f(n)≡f*(n)这个条件是有的。
那么A*可以保证最优解。
zorro09
2005-07-18
打赏
举报
回复
看陆汝钅今的书的人说能。看蔡自兴的书的人说不能。
ZeroGts
2005-07-17
打赏
举报
回复
在适合的环境中正确地使用A*可以保证最优解;
否则就是错误的A*,也就不是A*了。
ensoniq
2005-07-14
打赏
举报
回复
楼主再做点贡献吧,把几个函数的定义重新再明确一下。
另,要否定最优解最有说服力的办法还是举出反例,这个有没有的?
熊主任
2005-07-12
打赏
举报
回复
如果选中了一个好的估价函数,那么就算找不到最优解那也能找到一个相当不错的解,否则很容易退化成深度优先搜索,那么效率和找到的结果可能就都不理想了。
NewStarSE
2005-06-30
打赏
举报
回复
没人了?
NewStarSE
2005-06-29
打赏
举报
回复
TO: ensoniq
f(n)是由g(n)和h(n)两部分构成,而g(n)一般是取的实际发生的耗费,这个值显然有:g(n)≥g*(n),所以通常都不必考虑它。
不过在目标节点处,是不是能保证g(x)≡g*(x)呢?如果等式恒成立,则在目标节点处必有f(n)≡f*(n),那么条件4就是多余的。反之就有f(n)〉f*(n),蔡的考虑就是对的。
写到这里,终于明白了:A*算法并不要求g(x)≡g*(x),这也是作者们的分歧所在。但我现在认为也许这一条件已经隐含在其它条件中,我再想一想,也欢迎各位继续讨论。
thirdapple
2005-06-28
打赏
举报
回复
蔡是对的
NewStarSE
2005-06-28
打赏
举报
回复
看各位的,越看越晕。我干脆把书上的抄下来,请各位发表高见。
先看A*算法的定义(这个应该是公认的):
1、估值函数:f(n)=g(n)+h(n)
g(n)是已经发生的耗费,h(n)是将要发生的耗费的估值
2、f(n)单调非减
3、h(x)≤h*(x),对于任意的节点x都成立
4、从优先队列的队头取出节点
(a)检测该节点是否为目标节点,是,则求得解,返回该节点。
(b)不是目标节点,则根据f(n)的大小展开子节点到优先队列中(还有一些细节,省了)
5、重复第4步,至队列为空
陆是这么说的:由于H*算法是可采用的(即求出的第一个可行解就是最优解),而A*算法只不过是将与H*算法的限制(即h(x)≤h*(x))用于A算法而得到的,所以A*算法也是可采用的,即A*算法保证得到最优解。
蔡、傅是这么说的:算法要是可采用的,需要满足4个充分条件,除了前面提到的3个条件,还有一个:在目标节点处,需要f(n)≡f*(n),而A*算法并没有这一限制,所以不能保证得到最优解。
信谁的呢?
galois_godel
2005-06-28
打赏
举报
回复
看你怎么搜了,你可以搜可行解,这时找到的就不一定是最优解,如果你搜索的最优解,那就可以保证
sun3411
2005-06-28
打赏
举报
回复
决定于h(n)吧
h(n)<=实际该点到目标最近距离
能得到最优解
h(n)==0就是广度优先搜索
h(n)>实际该点到目标最近距离 不能得到最优解 效率较高
ensoniq
2005-06-28
打赏
举报
回复
请教下,目标节点处h(n)和h*(n)难道不是都为0吗?f(n)怎么会不等于f*(n)呢?那么什么情况下第四个条件不成立?
NowCan
2005-06-27
打赏
举报
回复
我记得是有条件的,和启发函数有关。但是具体的忘了。
Tranquillo
2005-06-27
打赏
举报
回复
可以,如果存在
tatbaby
2005-06-27
打赏
举报
回复
如果解存在,保证找到的最优解
这个 王永庆的《人工智能与原理》里面给了证明……不过我没去看他怎么证的。不过前提是,你设计的算法确实是A*算法,哈哈
fireofhell
2005-06-27
打赏
举报
回复
如果存在的话,就可以找到
mathe
2005-06-27
打赏
举报
回复
不能保证
NewStarSE
2005-06-27
打赏
举报
回复
UP
thirdapple
2005-06-27
打赏
举报
回复
我觉得,从A*算法本身而言,只要启发函数能够保证无后效性就可以保证得到最优解
加载更多回复(1)
基于图搜索的规划
算法
之A*家族(二):双向A*
算法
本文深入探讨了双向A*
算法
,揭示了其在寻找最短路径时的优势与局限。虽然
不能
确保全局
最优解
,但双向A*在大多数情况下能提供接近最优的解决方案,尤其在起点和终点互换导致计算成本显著差异的情景下。通过两套独立的A*
算法
同时探索,双向A*能在
保证
找到可行路径的同时,有效减少计算资源的浪费。文章通过实例和伪代码详细阐述了
算法
原理,并讨论了其在实际应用中的价值。
启发式搜索
本文介绍了启发式搜索的概念,包括无信息搜索如DFS、BFS和一致代价搜索,以及启发式搜索的两种方法:A
算法
和A*搜索。A
算法
虽然
不能
保证
最优解
,但在许多情况下能快速接近目标。A*搜索通过引入加权估价函数确保找到最优路径。文章以HackerRank的 pacman-astar 问题为例,展示了A
算法
的代码实现,并指出其在特定案例中可能无法
得到
最优解
。最后,A*搜索作为A
算法
的优化版,能够有效解决这一问题。
【
算法
】A*
算法
与启发函数
本文介绍了A*
算法
的起源,将其与BFS、Dijkstra
算法
进行对比,并探讨了启发函数的性质。A*
算法
结合了Dijkstra
算法
的
最优解
保证
和贪心搜索的效率,通过估价函数h(n)确保找到最短路径。当h(n)=0时,A*退化为Dijkstra
算法
;h(n)精确时,仅走最短路径;而h(n)过大则可能找不到最短路径。文中还提供了A*
算法
的Python实现。
【规划】A*
算法
以及c++实现
本文介绍了A*
算法
的核心思想,包括估价函数的设计,以及其与Dijkstra
算法
的比较。A*
算法
通过维护Open表来寻找最优路径,启发函数的选择影响
算法
效率和精度。文章还详细阐述了A*
算法
的步骤,并提到了C++实现的相关文件。在实际应用中,启发函数常采用欧几里得距离或曼哈顿距离。
路径规划A*
算法
A*
算法
结合了Dijkstra
算法
和Best-First Search的优点,能够高效地找到起点到终点的最优路径。它通过评估函数g(n)和h(n)进行路径估算,其中h(n)表示节点到目标的预估距离。当h(n)准确时,
算法
能确保找到
最优解
。常见的评估函数包括欧几里得、曼哈顿和切比雪夫距离。A*
算法
的伪代码和MATLAB实现也在文中给出。
数据结构与算法
33,026
社区成员
35,336
社区内容
发帖
与我相关
我的任务
数据结构与算法
数据结构与算法相关内容讨论专区
复制链接
扫一扫
分享
社区描述
数据结构与算法相关内容讨论专区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章