人工智能-八数码游戏问题

人工智能-八数码游戏问题

ID:5184277

大小:117.76 KB

页数:16页

时间:2017-12-05

人工智能-八数码游戏问题_第1页
人工智能-八数码游戏问题_第2页
人工智能-八数码游戏问题_第3页
人工智能-八数码游戏问题_第4页
人工智能-八数码游戏问题_第5页
资源描述:

《人工智能-八数码游戏问题》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、实验一:八数码游戏问题一、八数码游戏问题简介 九宫排字问题(又称八数码问题)是人工智能当中有名的难题之一。问题是在 3×3方格盘上,放有八个数码,剩下第九个为空,每一空格其上下左右的数码可移至空格。问题给定初始位置和目标位置,要求通过一系列的数码移动,将初始位置转化为目标位置。 2831231648475765(a)初始状态(b)目标状态图八数码游戏 二、实验目的 1. 熟悉人工智能系统中的问题求解过程; 2. 熟悉状态空间的盲目搜索和启发式搜索算法的应用;3. 熟悉对八数码问题的建模、求解及编程语言的应用。三、实验的思路八数码问题:在3×3的方格棋盘上,摆放着1到8这八个数码,有1个方

2、格是空的,其初始状态如图1所示,要求对空格执行空格左移、空格右移、空格上移和空格下移这四个操作使得棋盘从初始状态到目标状态。例如:28312316484705765(a)初始状态(b)目标状态图1八数码问题示意图1.启发函数设定由八数码问题的部分状态图可以看出,从初始节点开始,在通向目标节点的路径上,各节点的数码格局同目标节点相比较,其数码不同的位置个数在逐渐减少,最后为零,因此可以把数码不同的位置个数作为标志一个节点到目标节点距离远近的一个启发性信息,利用这个信息来扩展节点的选择,减少搜索范围,提高搜索速度。2.搜索过程:(搜索采用广度搜索方式,利用待处理队列辅助,逐层搜索(跳过劣质节

3、点))a、把初始数码组压入队列;b、从队列中取出一个数码组节点;c、扩展子节点,即从上下左右四个方向移动空格,生成相应子节点:d、对子节点数码组作评估,是否为优越节点,即其评估值是否小于等于其父节点加一,是则将其压入队,否则抛弃。e、判断压入队的子节点数码组(优越点)的评估值,为零则表示搜索完成,退出搜索;f、跳到步骤2;四、数据结构的设计数码结构体typedefstructnode//八数码结构体{intform[N][N];//数码组intevalue;//评估值,差距intudirec;//所屏蔽方向,防止往回推到上一状态,1上2下3左4右structnode*parent;//父

4、节点}Graph;Graph*Qu[MAX];//队列Graph*St[MAX];//堆栈起始把s放入open表失败成功是否open表为空表?是把open表中的第一个节点n移入close表否扩展节点n,把其后裔放入open表的前头是否有后继节点为目标节点?否是五、实验过程及代码#include}//设计了搜索深度范围,防止队列内存越界#include#include#defineN3//数码组大小#defineMax_Step50//最大搜索深度#defineMAX50typedefstructnode//八数码结构体{intform

5、[N][N];//数码组intevalue;//评估值intudirect;//所屏蔽方向,防止往回推到上已状态,1上2下3左4右structnode*parent;//父节点}Graph;Graph*Qu[MAX];//队列Graph*St[MAX];//堆栈/////////打印数码组voidPrint(Graph*The_graph){inti,j;if(The_graph==NULL)printf("图为空");else{printf("---------------------");for(i=0;i

6、t");for(j=0;j

7、++){printf("%dt",The_graph->form[i][j]);//遍历打印}printf("t

8、");}printf("

9、ttt差距:%dt

10、",The_graph->evalue);//差距显示printf("---------------------");}}/////////评价函数intEvaluate(Graph*The_graph,Graph*End_graph){intvalute=0;//差距数inti,j;for(i=0;iform[i][j]!=En

11、d_graph->form[i][j]){valute++;}}}The_graph->evalue=valute;returnvalute;}/////////移动数码组Graph*Move(Graph*The_graph,intDirect,intCreatNew_graph){Graph*New_graph;intHasGetBlank=0;//是否获取空格位置intAbleMove=1;//是否可移动inti,j,t_i,t

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。