八数码难题
我们看到这个题的第一感觉就是BFS,显然BFS可做
经过我坚持不懈的努力发现了问题所在
我们发现,这个题具有一定的奇特性质:
既知道起始状态也知道终点状态
我们就想到了运用双向BFS的内容(一开始也我也不会)
大体是记录空格位置和棋盘状态,加入队列不断增加节点入队。同时注意判重,将棋盘转换为九位数(如果第一个数字为0则是八位数),用hash表解决
双向宽搜,顾名思义就是从两边搜,适用于已知起始状态和目标状态,求最短步骤的题目。
我们可以开两类数组,分别表示正方方向搜索的队列,然后初始,目标状态分别入对应队列,进行扩展节点,直到两个方向搜索相遇时即得出最短步骤。
出于优化时间的目的,我们往往先搜队列中节点少的方向,轮流进行。
具体讲就是:两个方向根据队列中节点数交替扩展节点,每扩展一个节点为,在本队列判重后还要在另一个方向的队列中找是否出现,出现说明相遇,输出最短步骤为正方方向扩展到该节点所需最短步骤。
注意双向广搜时,反方向扩展节点时操作与正方向相反,比如向左移动要变为向右移动,但这点对本题没有影响。
这里找了一份比较好看的代码,相对来说比较容易理解
#include
#include
#include
#include