西电人工智能大作业.doc

西电人工智能大作业.doc

ID:51859789

大小:388.50 KB

页数:14页

时间:2020-03-17

西电人工智能大作业.doc_第1页
西电人工智能大作业.doc_第2页
西电人工智能大作业.doc_第3页
西电人工智能大作业.doc_第4页
西电人工智能大作业.doc_第5页
资源描述:

《西电人工智能大作业.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、02115093邹旭苗02115095王欣人工智能及其应用大作业邹旭苗02115093王欣0211509502115093邹旭苗02115095王欣八数码难题一、实验名称八数码难题的启发式搜索二、实验目的八数码问题:在3×3的方格棋盘上,摆放着1到8这八个数码,有1个方格是空的,其初始状态如图1所示,要求对空格执行空格左移、空格右移、空格上移和空格下移这四个操作使得棋盘从初始状态到目标状态。要求:1.熟悉人工智能系统中的问题求解过程;2.熟悉状态空间的启发式搜索算法的应用;3.熟悉对八数码问题的建模、求解及编程语言的应用。三

2、、实验设备及软件环境1.实验编程工具:VC++6.02.实验环境:Windows764位四、实验方法:启发式搜索1.算法描述1.将S放入open表,计算估价函数f(s)2.判断open表是否为空,若为空则搜索失败,否则,将open表中的第一个元素加入close表并对其进行扩展(每次扩展后加入open表中的元素按照代价的大小从小到大排序,找到代价最小的节点进行扩展)注:代价的计算公式f(n)=d(n)+w(n).其中f(n)为总代价,d(n)为节点的度,w(n)用来计算节点中错放棋子的个数。判断i是否为目标节点,是则成功,否则

3、拓展i,计算后续节点f(j),利用f(j)对open表重新排序2.算法流程图:02115093邹旭苗02115095王欣3.程序源代码:#include#include#include#includetypedefstructnode{inti,cost,degree,exp,father;inta[3][3];structnode*bef,*late;structnode*son;}treenode;intflag=0,count=1,num=0

4、,i=0;voidset(treenode*s);voidcpynode(treenode*s1,treenode*s2);voidadd1(treenode*s,treenode*open);voidadjust1(treenode*close);02115093邹旭苗02115095王欣voidjscost(treenode*s);voidtiaozheng(treenode*open);voidsortopen(treenode*open);inttest(treenode*s1,treenode*s2);voidpo

5、sition(treenode*s,treenode*open,treenode*close,treenode*s1);voidprintstr(treenode*open);intsearch(treenode*s1,treenode*s2);voidinput(treenode*s);intcmpnode(treenode*s1,treenode*s2);voidprint(treenode*s);voidadd(treenode*s,treenode*close);voidxuhao(treenode*s);voide

6、xtend(treenode*r1,treenode*s,treenode*s1,treenode*open,treenode*close);voidmain(){treenode*s0,*s1,*s;treenode*open,*close,*opend,*closed;open=(treenode*)malloc(sizeof(treenode));close=(treenode*)malloc(sizeof(treenode));open->late=NULL;close->late=NULL;opend=open;c

7、losed=close;s0=(treenode*)malloc(sizeof(treenode));set(s0);s1=(treenode*)malloc(sizeof(treenode));set(s1);printf("请输入八数码的初始状态:(以空格为分隔)");input(s0);printf("请输入八数码的目标状态:(以空格为分隔)");input(s1);xuhao(s0);02115093邹旭苗02115095王欣add(s0,opend);while(open->late!=NULL&&flag

8、==0){s=(treenode*)malloc(sizeof(treenode));cpynode(s,open->late);open=open->late;add(s,close);if(test(s,s1)==0){flag=1;}else{position(s,open,clos

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

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

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