第5章 搜索法
- 格式:ppt
- 大小:1.68 MB
- 文档页数:87
第五章搜索策略习题参考解答5.1 练习题5.1 什么是搜索?有哪两大类不同的搜索方法?两者的区别是什么?5.2 用状态空间法表示问题时,什么是问题的解?求解过程的本质是什么?什么是最优解?最优解唯一吗?5.3 请写出状态空间图的一般搜索过程。
在搜索过程中OPEN表和CLOSE表的作用分别是什么?有何区别?5.4 什么是盲目搜索?主要有几种盲目搜索策略?5.5 宽度优先搜索与深度优先搜索有何不同?在何种情况下,宽度优先搜索优于深度优先搜索?在何种情况下,深度优先搜索优于宽度优先搜索?5.6 用深度优先搜索和宽度优先搜索分别求图5.10所示的迷宫出路。
图5.10 习题5.6的图5.7 修道士和野人问题。
设有3个修道士和3个野人来到河边,打算用一条船从河的左岸渡到河的右岸去。
但该船每次只能装载两个人,在任何岸边野人的数目都不得超过修道士的人数,否则修道士就会被野人吃掉。
假设野人服从任何一种过河安排,请使用状态空间搜索法,规划一使全部6人安全过河的方案。
(提示:应用状态空间表示和搜索方法时,可用(N m,N c)来表示状态描述,其中N m和N c分别为传教士和野人的人数。
初始状态为(3,3),而可能的中间状态为(0,1),(0,2),(0,3), (1,1),(2,1),(2,2),(3,0),(3,1),(3,2)等。
)5.8 用状态空间搜索法求解农夫、狐狸、鸡、小米问题。
农夫、狐狸、鸡、小米都在一条河的左岸,现在要把它们全部送到右岸去。
农夫有一条船,过河时,除农夫外,船上至多能载狐狸、鸡和小米中的一样。
狐狸要吃鸡,鸡要吃小米,除非农夫在那里。
试规划出一个确保全部安全的过河计划。
(提示:a.用四元组(农夫,狐狸,鸡,米)表示状态,其中每个元素都可为0或1,0表示在左岸,1表示在右岸;b.把每次过河的一种安排作为一个算符,每次过河都必须有农夫,因为只有他可以划船。
)5.9 设有三个大小不等的圆盘A 、B 、C 套在一根轴上,每个圆盘上都标有数字1、2、3、4,并且每个圆盘都可以独立地绕轴做逆时针转动,每次转动90°,初始状态S 0和目标状态S g 如图5.11所示,用宽度优先搜索法和深度优先搜索法求从S 0到S g 的路径。
5.1.什么是搜索?有哪两大类不同的搜索方法?二者的区别是什么?根据实际情况,按照一定的策略或规则,从知识库中寻找可利用的知识,从而构造出一条使问题获得解决的推理路线的过程,就称为搜索搜索一般分为盲目搜索和启发式搜索。
盲目搜索又称为无信息搜索,即在搜索过程中,只按预先规定的搜索控制策略进行搜索,而没有任何中间信息来改变这些控制策略。
由于这种搜索的控制策略都是预定的,不管什么问题都采用这样的控制策略,这就使得搜索带有盲目性,效率不高。
只适用于解决较简单问题。
启发式搜索又称有信息搜索,它是指在求解过程中,根据问题本身的特性或搜索过程中产生的一些信息来不断地改变或调整搜索的方向,使搜索朝着最有希望的方向前进,加速问题的求解,并找到最优解。
启发式搜索由于考虑到问题本身的特性并利用这些特性,从而使搜索求解的效率更高,更易于求解复杂问题5.2什么是启发式搜索,什么是启发信息?5.3请阐述状态空间的一般搜索过程。
OPEN表与CLOSED表的作用是什么?有何区别?1) 把初始节点S0放入OPEN表,并建立只含S0的图,记为G2) 检查OPEN表是否为空,若为空则问题无解,退出3) 把OPEN表的第一个节点取出放入CLOSE表,记该节点为节点n4) 观察节点n是否为目标节点,若是,则求得问题的解,退出5) 扩展节点n,生成一组子节点。
把其中不是节点n先辈的那些子节点记作集合M,并把这些节点作为节点n的子节点加入G中。
6)针对M中子节点的不同情况,分别进行如下处理对于那些未曾在G中出现过的M成员设置一个指向父节点(n)的指针,并把它放入OPEN表对于那些先前已在G中出现过的M成员,确定是否要修改指向父节点的指针对于那些先前已在G中出现,并且已经扩展了的M成员,确定是否需要修改其后继结点指向父节点的指针7) 按某种搜索策略对OPEN表中的节点进行排序8) 转第2步OPEN表:用于存放刚生成的节点CLOSE表:用于存放将要扩展或已扩展的节点区别:存放节点节点不同,open表存放未扩展的节点,closed表存放已经扩展的节点。
5.1 .什么是搜索?有哪两大类不同的搜索方法?二者的区别是什么?根据实际情况,按照一定的策略或规则,从知识库中寻找可利用的知识,从而构造出一条使问题获得解决的推理路线的过程,就称为搜索搜索一般分为盲目搜索和启发式搜索。
盲目搜索又称为无信息搜索,即在搜索过程中,只按预先规定的搜索控制策略进行搜索,而没有任何中间信息来改变这些控制策略。
由于这种搜索的控制策略都是预定的,不管什么问题都采用这样的控制策略,这就使得搜索带有盲目性,效率不高。
只适用于解决较简单问题。
启发式搜索又称有信息搜索,它是指在求解过程中,根据问题本身的特性或搜索过程中产生的一些信息来不断地改变或调整搜索的方向,使搜索朝着最有希望的方向前进,加速问题的求解,并找到最优解。
启发式搜索由于考虑到问题本身的特性并利用这些特性,从而使搜索求解的效率更高,更易于求解复杂问题5.2 什么是启发式搜索,什么是启发信息?启发式搜索就是在状态空间中的搜索对每一个搜索的位置进行评估,得到最好的位置,再从这个位置进行搜索直到目标。
为减小搜索范围而需要利用某些已知的,有关具体问题领域的特性信息。
5.3 请阐述状态空间的一般搜索过程。
OPEN表与CLOSED表的作用是什么?有何区别?1) 把初始节点S0 放入OPEN表,并建立只含S0的图,记为G2) 检查OPEN表是否为空,若为空则问题无解,退出3) 把OPEN表的第一个节点取出放入CLOSE表,记该节点为节点n4) 观察节点n 是否为目标节点,若是,则求得问题的解,退出5) 扩展节点n,生成一组子节点。
把其中不是节点n 先辈的那些子节点记作集合M,并把这些节点作为节点n 的子节点加入G中。
6) 针对M中子节点的不同情况,分别进行如下处理对于那些未曾在G 中出现过的M成员设置一个指向父节点( n)的指针,并把它放入OPEN 表对于那些先前已在G中出现过的M成员,确定是否要修改指向父节点的指针对于那些先前已在G中出现,并且已经扩展了的M成员,确定是否需要修改其后继结点指向父节点的指针7) 按某种搜索策略对OPEN表中的节点进行排序8) 转第2 步OPEN表:用于存放刚生成的节点CLOSE表:用于存放将要扩展或已扩展的节点区别:存放节点节点不同,open 表存放未扩展的节点,closed 表存放已经扩展的节点。