八数码问题C语言A星算法详细实验资料报告材料含代码

上传人:hs****ma 文档编号:431374842 上传时间:2022-08-23 格式:DOC 页数:16 大小:211.50KB
返回 下载 相关 举报
八数码问题C语言A星算法详细实验资料报告材料含代码_第1页
第1页 / 共16页
八数码问题C语言A星算法详细实验资料报告材料含代码_第2页
第2页 / 共16页
八数码问题C语言A星算法详细实验资料报告材料含代码_第3页
第3页 / 共16页
八数码问题C语言A星算法详细实验资料报告材料含代码_第4页
第4页 / 共16页
八数码问题C语言A星算法详细实验资料报告材料含代码_第5页
第5页 / 共16页
点击查看更多>>
资源描述

《八数码问题C语言A星算法详细实验资料报告材料含代码》由会员分享,可在线阅读,更多相关《八数码问题C语言A星算法详细实验资料报告材料含代码(16页珍藏版)》请在金锄头文库上搜索。

1、word一、实验容和要求八数码问题:在33的方格棋盘上,摆放着1到8这八个数码,有1个方格是空的,其初始状态如图1所示,要求对空格执行空格左移、空格右移、空格上移和空格下移这四个操作使得棋盘从初始状态到目标状态。例如:28312316484705765(a) 初始状态 (b) 目标状态图1 八数码问题示意图请任选一种盲目搜索算法广度优先搜索或深度优先搜索或任选一种启发式搜索方法全局择优搜索,加权状态图搜索,A算法或 A* 算法编程求解八数码问题初始状态任选。选择一个初始状态,画出搜索树,填写相应的OPEN表和CLOSED表,给出解路径,对实验结果进展分析总结,得出结论。二、实验目的1. 熟悉人

2、工智能系统中的问题求解过程;2. 熟悉状态空间的盲目搜索和启发式搜索算法的应用;3. 熟悉对八数码问题的建模、求解与编程语言的应用。三、实验算法A*算法是一种常用的启发式搜索算法。在A*算法中,一个结点位置的好坏用估价函数来对它进展评估。A*算法的估价函数可表示为: f(n) = g(n) + h(n) 这里,f(n)是估价函数,g(n)是起点到终点的最短路径值也称为最小消耗或最小代价,h(n)是n到目标的最短路经的启发值。由于这个f(n)其实是无法预先知道的,所以实际上使用的是下面的估价函数:f(n) = g(n) + h(n) 其中g(n)是从初始结点到节点n的实际代价,h(n)是从结点n

3、到目标结点的最优路径的估计代价。在这里主要是h(n)表现了搜索的启发信息,因为g(n)是的。用f(n)作为f(n)的近似,也就是用g(n)代替g(n),h(n)代替h(n)。这样必须满足两个条件:1g(n)=g(n)大多数情况下都是满足的,可以不用考虑,且f必须保持单调递增。2h必须小于等于实际的从当前节点到达目标节点的最小消耗h(n)=h(n)。第二点特别的重要。可以证明应用这样的估价函数是可以找到最短路径的。3.A*算法的步骤A*算法根本上与广度优先算法一样,但是在扩展出一个结点后,要计算它的估价函数,并根据估价函数对待扩展的结点排序,从而保证每次扩展的结点都是估价函数最小的结点。A*算法

4、的步骤如下:1建立一个队列,计算初始结点的估价函数f,并将初始结点入队,设置队列头和尾指针。2取出队列头队列头指针所指的结点,如果该结点是目标结点,如此输出路径,程序完毕。否如此对结点进展扩展。 3检查扩展出的新结点是否与队列中的结点重复,假设与不能再扩展的结点重复位于队列头指针之前,如此将它抛弃;假设新结点与待扩展的结点重复位于队列头指针之后,如此比拟两个结点的估价函数中g的大小,保存较小g值的结点。跳至第五步。4如果扩展出的新结点与队列中的结点不重复,如此按照它的估价函数f大小将它插入队列中的头结点后待扩展结点的适当位置,使它们按从小到大的顺序排列,最后更新队列尾指针。5如果队列头的结点还

5、可以扩展,直接返回第二步。否如此将队列头指针指向下一结点,再返回第二步。四、程序框图五、实验结果与分析输入初始状态:2 8 3目标状态:1 2 31 6 48 0 47 0 57 6 5运行结果屏幕打印OPEN表与CLOSE表:OPENCLOSE1 2 3 4 02 3 4 5 60 12 3 4 6 70 1 52 3 4 6 8 90 1 5 72 3 4 8 9 100 1 5 7 62 3 4 8 11 12 13 0 1 5 7 6 92 3 4 8 12 13 14 150 1 5 7 6 9 113 4 8 12 13 14 15 16 170 1 5 7 6 9 11 24 8

6、 12 13 14 15 16 17 18 190 1 5 7 6 9 11 2 34 8 12 13 14 15 16 17 19 200 1 5 7 6 9 11 2 3 188 12 13 14 15 16 17 19 21 220 1 5 7 6 9 11 2 3 18 412 13 14 15 16 17 19 21 22 230 1 5 7 6 9 11 2 3 18 4 812 13 14 15 16 17 19 21 22 24 250 1 5 7 6 9 11 2 3 18 4 8 2312 13 14 15 16 17 19 21 22 24 260 1 5 7 6 9 1

7、1 2 3 18 4 8 23 24发现26为目标节点072 8 31 0 47 6 5搜索树:2.112 8 31 6 47 0 5172 0 31 8 47 6 54.112 8 31 4 07 6 53.112 8 30 1 47 6 522.142 8 31 4 57 6 02 8 37 1 40 6 52 8 31 4 37 6 50 8 32 1 47 6 52 8 31 6 47 5 010.142 8 31 6 47 0 5692 3 01 8 47 6 5580 2 31 8 47 6 5791 2 30 8 47 6 510.112 3 41 8 07 6 518 0 32

8、 1 47 6 5注释:每个方格中最上面两个数字分别为编号与启发值,下面九个数字为八数码。较粗的箭头为解路径8.121 2 37 8 40 6 59.101 2 38 0 47 6 511.91 0 38 2 47 6 523.91 2 37 8 46 0 513.131 2 38 4 07 6 512.131 2 38 6 47 0 524.81 2 37 0 46 8 521 2 37 8 46 5 00 1 38 2 47 6 53 1 08 2 47 6 5目标节点六、结论对于八数码问题,BFS算法最慢,A*算法较快。八数码问题的一个状态实际上是09的一个排列,对于任意给定的初始状态和

9、目标,不一定有解,也就是说从初始状态不一定能到达目标状态。因为排列有奇排列和偶排列两类,从奇排列不能转化成偶排列。如果一个数字08的随机排列871526340,用F(X)表示数字X前面比它小的数的个数,全部数字的F(X)之和为Y=(F(X),如果Y为奇数如此称原数字的排列是奇排列,如果Y为偶数如此称原数字的排列是偶排列。因此,可以在运行程序前检查初始状态和目标状态的排序的奇偶行是否一样,一样如此问题可解,应当能搜索到路径。否如此无解。七、源程序与注释#include #include #include using namespace std;const int ROW = 3;const in

10、t COL = 3;const int MAXDISTANCE = 10000;const int MAXNUM = 10000;int abs(int a)if (a0) return a;else return -a;typedef struct _Nodeint digitROWCOL;int dist; / 距离 int dep; / 深度int index; / 索引值 Node;Node src, dest;vector node_v; / 储存节点 bool isEmptyOfOPEN() /判断Open表是否空 for (int i = 0; i node_v.size();

11、i+) if (node_vi.dist != MAXNUM) return false;return true;bool isEqual(int index, int digitCOL) /判断节点是否与索引值指向的节点一样 for (int i = 0; i ROW; i+) for (int j = 0; j COL; j+) if (node_vindex.digitij != digitij) return false; return true;ostream& operator(ostream& os, Node& node) for (int i = 0; i ROW; i+)

12、for (int j = 0; j COL; j+) os node.digitij ; os endl;return os;void PrintSteps(int index, vector& rstep_v) /输出步骤 rstep_v.push_back(node_vindex);index = node_vindex.index;while (index != 0) rstep_v.push_back(node_vindex); index = node_vindex.index;for (int i = rstep_v.size() - 1; i = 0; i-) cout Step

13、 rstep_v.size() - i endl rstep_vi endl;void Swap(int& a, int& b) /交换 int t;t = a;a = b;b = t;void Assign(Node& node, int index) /获取节点 for (int i = 0; i ROW; i+) for (int j = 0; j COL; j+) node.digitij = node_vindex.digitij;int GetMinNode() /获取启发值最小的节点 int dist = MAXNUM;int loc; / the location of minimize nodefor (int i = 0; i node_v.size(); i+) if (node_vi.dist = MAXNUM) continue; else if (node_vi.dist + node_vi.dep) dist) loc = i; di

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号