迭代加深搜索、启发式搜索、A*、IDA

目录

回顾/本期梗概

一、迭代加深搜索(IDDFS)

        1、IDDFS基础知识

        1)什么是迭代加深搜索

         2)迭代加深的基本结构

         3)IDDFS和BFS比较优势是什么

        4)IDDFS中的复杂计算问题

二、A*算法

        1、A*算法基础知识

        1.什么是A*算法

        2.A*算法的核心思想、

         3、A*算法的核心要点:

        相关说明:

        (1)为什么终点出队说明最短?

        (2)为什么非终点出队,不一定是最优解?

三、IDA*

        1、IDA*基础知识

        1)什么是IDA*

        2)IDA*和A*的区别


回顾/本期梗概

        上期我们学习了搜索优化、搜索进阶(空降链接)本期我们将学习迭代加深搜索、启发式搜索、A、IDA。


一、迭代加深搜索(IDDFS)

        1、IDDFS基础知识

        1)什么是迭代加深搜索

        迭代加深搜索(IDDFS)是深度优先搜索,与普通的dfs不同的是,每次深搜都会有搜索的最大深度限制,如果没有找到解,那么就增大深度,再进行深搜,如此循环直到找到的解为止,这样可以找到最浅层的解。

        IDDFS适和求解:搜索深度较深,但正确的解再较浅的深度的问题。

        IDDFS的使用前提是:一定要有解。

        

         2)迭代加深的基本结构

while(!dfs(maxdep))
    maxdep++;

         3)IDDFS和BFS比较优势是什么

        BFS 的基础是一个队列,队列的空间复杂度很大,当状态比较多或者当状态比较大时,使用队列的BFS就显出了了劣势。事实上,迭代加深就类似于用DFS方式实现的BFS,他的空间复杂度相对较小。

        IDDFS和BFS相比的优势在于:空间复杂度会小很多,也可以配合剪枝来提升搜索效率。

        4)IDDFS中的复杂计算问题

        当搜索树的分支比较多时,每增加一层的搜索复杂度会出现指数级爆炸式增长,这时前面重复的部分所带来的复杂度几乎可以忽略,这也就是为什么迭代加深可以近似看成BFS的。


二、A*算法

        1、A*算法基础知识

        启发式搜索(Heurisrically Search)又称为有信息搜索(Informed Search),它是利用问题拥有的启发信息来引导搜索,达到减少搜索范围、减低问题复杂度的目的,这种利用启发信息的搜索过程称为启发式搜索。

        启发式策略:可以通过指导搜索向最有希望的方向前进,降低了复杂度。通过删除某些状态及其延伸,启发式算法可以消除组合爆炸,并得到令人能接受的解。

        1.什么是A*算法

        A*算法,A*(A-Star)算法是一种静态路网中求解最短路径最有效的直接搜索方法。

        2.A*算法的核心思想、

        A*算法的核心思想:使用一下队列BFS,并结合估价函数,每次取出优先队列中总代价最低点进行BFS扩展。这种带有估价函数的优先队列BFS算法,就是A*算法。

        例子:求S点到T点的最短路。

        

        普通BFS:

         A*算法:

        使用A*算法,优先队列维护:d[u]+f[u]

        设:f[u]=该点到终点的曼哈顿距离

        类似优先队列BFS,走到不能证明最短,出队才能说明是最短

         3、A*算法的核心要点:

        A.设f(x)代表了x点到终点的估计值,g(x)代表了x点到终点的最终实际值,则一定要满足:f(x)\leqslant g(x),也就是:估计值必须\leqslant最终实际值,估价函数才有意义。

                a、当:f(x)=0时,A*算法退化为普通的优先队列BFS的算法;

                b、当问题无解时,A*算法退化为朴素的BFS但由于A*算法要维护优先队列,因此此效率低于朴素的BFS。

        B.目标状态在第1次从优先队列取出时,就得到了最优解。

        C.搜索看见比较庞大且问题一定有解时,A*算法的优势才会比较明显;

        D.出兑就是最小距离的性质,只对终点成立,对其他的点不一定成立,且每个点可能会被讨论多次。

        相关说明:

        (1)为什么终点出队说明最短?

        假设u点出队,到u点的最短路为d(u),u点到终点的估计值为f(u),实际值为g(u)

        \because f(u)\leqslant g(u)

        \therefore d(u)+f(u)\leqslant d(u)+g(u)

        如果u点出队,说明d(u)+f(u)是当前队列的最小值,如果该值不是最优解,说明队列中有比其更小的值,与优先队列维护最小值的性质矛盾,因此u点出列时,一定能得到u点的最优解。

        注意:如果u点是终点,则g(u)=0.

        (2)为什么非终点出队,不一定是最优解?

        设:1,2,4,5点的f(x)=0,走其余点f(x)=g(x),A*算法对估价函数的要求是f(x)\leqslant g(x)因此,设置2种不同的估计函数并不影响算法的正确性。

        则:d(x)+f(x)的结果将如图所示

        讨论发现:

        A.点5出队时,到点5的最短路计算出来是3,这并不是最优解,只是因为1,2,4,5点的估价函数较小,因此点5先出队。

        B.当走到点6时,d(x)+f(x)的最小值不是点6,而是点3,因此有机会更正之前错误的解,重新用点3更新点5.


三、IDA*

        1、IDA*基础知识

        1)什么是IDA*

        IDA*算法是:基于迭代加深的A*算法。迭代加深只有在状态呈指数级增长时才有较好的效果,而A*就是为了防止状态呈指数级增长的。

        IDA*算法本质上是:同时运用迭代加深与全局最优性剪枝。

        2)IDA*和A*的区别

        A*=BFS+启发函数

        IDA*=IDDFS+启发函数

        IDA*由于是深搜,空间消耗相对A*更少。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/905046.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

102. UE5 GAS RPG 实现范围技能奥术伤害

在上一篇文章里,我们在技能蓝图里实现了通过技能实现技能指示,再次触发按键后,将通过定时器触发技能效果表现,最多支持11个奥术个体效果的播放。 在这一篇里,我们将实现技能播放时,对目标敌人应用技能伤害。…

Android OpenGL ES详解——裁剪Scissor

目录 一、概念 二、如何使用 1、开启裁剪测试 2、关闭裁剪测试 3、指定裁剪窗口(位置和大小) 4、裁剪应用举例 三、窗口、视⼝和裁剪区域三者区别 四、源码下载 一、概念 定义1: 裁剪是OpenGL中提⾼渲染的⼀种方式,只刷新…

内存马浅析

之前在jianshu上写了很多博客,但是安全相关的最近很多都被锁了。所以准备陆陆续续转到csdn来。内存马前几年一直是个很热门的漏洞攻击手段,因为相对于落地的木马,无文件攻击的内存马隐蔽性、持久性更强,适用的漏洞场景也更多。 J…

华为配置 之 GVRP协议

目录 简介: 配置GVRP: 总结: 简介: GVRP(GARP VLAN Registration Protocol),称为VLAN注册协议,是用来维护交换机中的VLAN动态注册信息,并传播该信息到其他交换机中&…

62 mysql 中 存储引擎MyISAM 中索引的使用

前言 固定数据表 mysql. tables_priv 的表结构创建如下 CREATE TABLE tables_priv (Host char(60) COLLATE utf8_bin NOT NULL DEFAULT ,Db char(64) COLLATE utf8_bin NOT NULL DEFAULT ,User char(32) COLLATE utf8_bin NOT NULL DEFAULT ,Table_name char(64) COLLATE u…

局长们,今晚0点,国考抢考点!

2025国考报名确认已于11月1日0:00开始已经报完名且通过资格审核的小伙伴们一定要及时确认! 具体流程是什么?操作时需要注意哪些事项?看完这篇就能全部搞定~ 25国考时间轴线 ✔️报名时间:10月15日8:00至10月24日18:00 ✔️审查时间:10月1…

list ------ 是一个带头双向循环的列表

结构 insert list 没有find&#xff0c;算法库有 #define _CRT_SECURE_NO_WARNINGS 1 #include<iostream> #include<algorithm> #include<list> using namespace std; class Pos {int _row;int _col; public:Pos(int row, int col):_row(row),_col(col){c…

【已解决】【hadoop】如何解决Hive连接MySQL元数据库的依赖问题

在启动 Hive 之前&#xff0c;通常不需要手动连接到 MySQL 数据库。Hive 的配置文件 hive-site.xml 中已经包含了连接到 MySQL 元数据库所需的信息&#xff0c;包括用户名和密码。当你启动 Hive 服务时&#xff0c;Hive 会使用这些配置信息自动连接到 MySQL 数据库。 为什么还要…

react基础之redux快速上手环境准备

文章目录 核心概念配置基础环境提交action传参异步状态操作redux调试-devtools配套工具 Redux 是一个状态管理库&#xff0c;通常与 React 一起使用&#xff0c;帮助开发者管理应用的全局状态。它的核心理念是将应用的状态存储在一个单一的、不可变的状态树中&#xff0c;并通过…

YashanDB安装及使用问题和常用总结

在YashanDB的安装和使用中总会遇到一些问题&#xff0c;有些抓耳挠腮各种查&#xff0c;在此总结下遇到和群友问到的一些问题&#xff0c;和一些常用总结 一、官方文档 先附上官方文档地址&#xff0c;给迷路的小伙伴&#xff0c;官方文档整体还是比较简介易懂的 安装部署 |…

Unreal5从入门到精通之如何解决在VR项目在头显中卡顿的问题

前言 以前我们使用Unity开发VR,Unity提供了非常便利的插件和工具来做VR。但是由于Unity的渲染效果不如Unreal,现在我们改用Unreal来做VR了,所有的VR相关的配置和操作都要重新学习。 今天就来总结一下,我在开发VR过程中碰到的所有问题。 1.编辑器,以VR运行 默认运行方式…

C#与C++交互开发系列(十四):C++中STL容器与C#集合传递的形式

前言 在跨语言开发中&#xff0c;C 的 STL 容器&#xff08;如 std::vector, std::map&#xff09;和 C# 的集合类&#xff08;如 List<T>, Dictionary<TKey, TValue>&#xff09;之间的数据传递是一个常见需求。由于两者的内存布局和实现机制不同&#xff0c;直接…

docker离线安装达梦数据库

文章目录 下载达梦数据库docker镜像上传DM8镜像文件将DM8镜像导入到本地docker镜像仓库中查看本地docker镜像仓库是否存在DM8镜像带参数启动DM8docker启动DM8默认用户名/密码 下载达梦数据库docker镜像 达梦数据库官网 https://www.dameng.com/ 点击下载中心&#xff0c;选择D…

智能合约分享

智能合约练习 一、solidity初学者经典示例代码&#xff1a; 1.存储和检索数据&#xff1a; // SPDX-License-Identifier: MIT pragma solidity ^0.8.0; // 声明 Solidity 编译器版本// 定义一个名为 SimpleStorage 的合约 contract SimpleStorage {// 声明一个公共状态变量 d…

Couldn‘t apply path mapping to the remote file.

Couldn’t apply path mapping to the remote file. /s6home2/zjw524/projects/seq2seq/code/deepnmtpycharm/deepNmt/code/deepNmtPycharm/deepNmt/model/Deep_NMT_Model.py can’t be found in project. You can continue debugging, but without the source. To fix that yo…

4.2-6 使用Hadoop WebUI

文章目录 1. 查看HDFS集群状态1.1 端口号说明1.2 用主机名访问1.3 主节点状态1.4 用IP地址访问1.5 查看数据节点 2. 操作HDFS文件系统2.1 查看HDFS文件系统2.2 在HDFS上创建目录2.3 上传文件到HDFS2.4 删除HDFS文件和目录 3. 查看YARN集群状态4. 实战总结 1. 查看HDFS集群状态 …

嵌入式硬件电子电路设计(一)开关电源Buck电路

目录 Buck电路基本结构 1. 开关闭合&#xff08;SW 闭合&#xff09; 2. 开关断开&#xff08;SW 断开&#xff09; 3. 开关控制和占空比 MP1584电路分析 其他Buck芯片的电路参考 Buck电路基本结构 下图是简化之后的BUCK电路主回路。下面分析输出电压的产生K闭合后&…

医院信息化与智能化系统(14)

医院信息化与智能化系统(14) 这里只描述对应过程&#xff0c;和可能遇到的问题及解决办法以及对应的参考链接&#xff0c;并不会直接每一步详细配置 如果你想通过文字描述或代码画流程图&#xff0c;可以试试PlantUML&#xff0c;告诉GPT你的文件结构&#xff0c;让他给你对应…

Unity 使用Netcode实现用户登录和登出

Unity之NetCode for GameObjets 基本使用 说明思路相关API代码实现Tips 说明 最近项目需要联机&#xff0c;项目方案选用Unity提供的NetCode for GameObjets&#xff08;以下简称NGO&#xff09;&#xff0c;踩了不少坑&#xff0c;本文不介绍基础使用&#xff0c;围绕双端&am…

【单机游戏】红色警戒游戏介绍和玩法

平地一声惊雷&#xff0c;金将军居然发射了洲际导弹&#xff0c;虽然我们不能亲自体验&#xff0c;但是我们可以自己在游戏中体验一把&#xff0c;今天就介绍一个很多80 90都玩过的即时战略游戏-红色警戒 https://pan.quark.cn/s/7aca45fa3dd7 红色警戒&#xff08;Red Alert …