【vc++精品源码栏目提醒】:网学会员,鉴于大家对vc++精品源码十分关注,论文会员在此为大家搜集整理了“用A算法解决八数码问题【毕业论文,绝对精品】 - 毕业设计”一文,供大家参考学习!
题目: 用 A算法解决八数码问题 摘要: 八数码问题是人工智能中一个很典型的智力问题。
本文以状态空间搜索的观点讨论了八数码问题,给出了八数码问题的 Java 算法与实现的思想,分析了 A 算法的可采纳性等及系统的特点。
关键词九宫重排,状态空间,启发式搜索,A 算法 1 引言九宫重排问题是人工智能当中有名的难题之一。
问题是在 3×3 方格盘上,放有八个数码,剩下一个位置为空,每一空格其上下左右的数码可移至空格。
问题给定初始位置和目标位置,要求通过一系列的数码移动,将初始状态转化为目标状态。
状态转换的规则:空格四周的数移向空格,我们可以看作是空格移动,它最多可以有4个方向的移动,即上、下、左、右。
九宫重排问题的求解方法,就是从给定的初始状态出发,不断地空格上下左右的数码移至空格,将一个状态转化成其它状态,直到产生目标状态。
一、 问题描述1.1 待解决问题的解释 八数码游戏(八数码问题)描述为:在 3×3 组成的九宫格棋盘上,摆有八个将牌,每一个将牌都刻有 1-8 八个数码中的某一个数码。
棋盘中留有一个空格,允许其周围的某一个将牌向空格移动,这样通过移动将牌就可以不断改变将牌的布局。
这种游戏求解的问题是:给定一种初始的将牌布局或结构(称初始状态) ,问如何移动将牌,实现从初始状态到目标状和一个目标的布局(称目标状态)态的转变。
1.2 问题的搜索形式描述(4 要素) 初始状态: 8 个数字将牌和空格在九宫格棋盘上的所有格局组成了问题的状态空间。
其中,状态空间中的任一种状态都可以作为初始状态。
后继函数: 通过移动空格(上、下、左、右)和周围的任一棋子一次,到达新的合法状态。
目标测试: 比较当前状态和目标状态的格局是否一致。
路径消耗: 每一步的耗散值为 1,因此整个路径的耗散值是从起始状态到目标状态的棋子移动的总步数。
1.3 解决方案介绍(原理) 对于八数码问题的解决,首先要考虑是否有答案。
每一个状态可认为是一个1×9 的矩阵,问题即通过矩阵的变换,是否可以变换为目标状态对应的矩阵?由数学知识可知,可计算这两个有序数列的逆序值,如果两者都是偶数或奇数,则可通过变换到达,否则,这两个状态不可达。
这样,就可以在具体解决问题之前判断出问题是否可解,从而可以避免不必要的搜索。
如果初始状态可以到达目标状态,那么采取什么样的方法呢? 常用的状态空间搜索有深度优先和广度优先。
广度优先是从初始状态一层一层向下找,直到找到目标为止。
深度优先是按照一定的顺序前查找完一个分支,再查找另一个分支,以至找到目标为止。
广度和深度优先搜索有一个很大的缺陷就是他们都是在一个给定的状态空间中穷举。
这在状态空间不大的情况下是很合适的算法,可是当状态空间十分大,且不预测的情况下就不可取了。
他的效率实在太低,甚至不可完成。
由于八数码问题状态空间共有 9个状态,对于八数码问题如果选定了初始状态和目标状态,有 9/2 个状态要搜索,考虑到时间和空间的限制,在这里采用 A算法作为搜索策略。
在这里就要用到启发式搜索 启发式搜索就是在状态空间中的搜索对每一个搜索的位置进行评估,得到最好的位置,再从这个位置进行搜索直到目标。
这样可以省略大量无畏的搜索路径,提到了效率。
在启发式搜索中,对位置的估价是十分重要的。
采用了不同的估价可以有不同的效果。
启发中的估价是用估价函数表示的,如:fn gn hn 其中 fn 是节点 n 的估价函数,gn是在状态空间中从初始节点到 n 节点的实际代价,hn是从 n 到目标节点最佳路径的估计代价。
在此八数码问题中,显然 gn就是从初始状态变换到当前状态所移动的步数,估计函数 fn我们就可采用当前状态各个数字牌不在目标状态未知的个数,即错位数。
二、 算法介绍2.1 搜索算法一般介绍 不管哪种搜索,都统一用这样的形式表示:搜索的对象是一个图,它面向一个问题,不一定有明确的存储形式,但它里面的一