人工智能实验报告26899.pdf
《人工智能实验报告26899.pdf》由会员分享,可在线阅读,更多相关《人工智能实验报告26899.pdf(17页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 *大学 人工智能基础课程实验报告(2011-2012 学年第一学期)启发式搜索 王浩算法 班 级:*学 号:*姓 名:*指导教师:*成 绩:2012 年 1 月 10 日 实验一 启发式搜索算法 1.实验内容:使用启发式搜索算法求解 8 数码问题。编制程序实现求解 8 数码问题A算法,采用估价函数 w nf nd np n,其中:d n是搜索树中结点n的深度;w n为结点n的数据库中错放的棋子个数;p n为结点n的数据库中每个棋子与其目标位置之间的距离总和。分析上述中两种估价函数求解 8 数码问题的效率差别,给出一个是 p n的上界的 h n的定义,并测试使用该估价函数是否使算法失去可采纳性
2、。2.实验目的 熟练掌握启发式搜索A算法及其可采纳性。3.实验原理 使用启发式信息知道搜索过程,可以在较大的程度上提高搜索算法的时间效率和空间效率;启发式搜索的效率在于启发式函数的优劣,在启发式函数构造不好的情况下,甚至在存在解的情形下也可能导致解丢失的现象或者找不到最优解,所以构造一个优秀的启发式函数是前提条件。4.实验内容 1.问题描述 在一个 3*3 的九宫格 里有 1 至 8 八个数以及一个空格随机摆放在格子中,如下图:初始状态 目标状态 现需将图一转化为图二的目标状态,调整的规则为:每次只能将空格与其相邻的一个数字进行交换。实质是要求给出一个合法的移动步骤,实现从初始状态到目标状态的
3、转变。2.算法分析 (1)解存在性的讨论 对于任意的一个初始状态,是否有解可通过线性代数的有关理论证明。按数组存储后,算出初始状态的逆序数和目标状态的逆序数,若两者的奇偶性一致,则表明有解。(2)估价函数的确定 2 8 3 1 6 1 2 3 8 0 通 过 对 八 数 码 的 特 性 的 研 究,找 出 一 个 相 对 好 的 函 数,f(n)=d(n)+h(n)其 中h(n)=2*compare(n)+3*S(n);d(n)为已搜索的深度;(compare(n)为当前节点与目标结点相同位置不相同的个数,S(n)为当前节点的无序度。)(3)节点的处理 取得一个结点后,判断是否有解,然后对其进
4、行扩展,用估价函数从中取得一个最优节点,依次循环将路径得到,直到取的最后的目标状态。(4)算法设计 a.输入初始结点,判断解的存在性,并与目标节点对比。b.若不是目标节点则进行扩展,生成其全部后继节点。c.对于每个后继节点均求其 f(n),并比较。d.将最小 f(n)存入正确路径,并与目标节点进行对比。e.若不是目标节点则循环执行 b,若是目标节点则输出 5 实验结果 输入输出:源代码如下:#include int final9=1,2,3,8,0,4,7,6,5;实验内容:实现命题逻辑框架内的王浩算法。将命题逻辑中的王浩算法推广至下述命题语言的情形之下:命题变量符号:1p,2p,3p,逻辑连
5、接符:,间隔符:(,)在上述中所定义的命题语言中实现王浩算法。2.实验目的 熟练掌握命题逻辑中的王浩算法。3.实验要求 实验题目必须由个人独立完成,允许自行参考相关文献资料,但严禁同学间相互拷贝和抄袭程序以及文档资料。实验结束后一周内上交实验报告和实验文档资料。提交的文档资料包括设计文档和程序源代码。设计文档和程序源代码以书面文档方式提供(用4A纸打印);并提交电子文档备查。四数据结构 给定公式,例如:(p1-(q1-r1)-(p1-q1)-(p1-r1)函数 inite 主要作用是负责将符号初始化成树的结构。函数 clone 复制一棵完全相同的符号树。函数 restruct 查找所有&,|,
6、等符号,并将其拆分成新形式:!,-符号。函数 searching 王浩算法的主要函数。函数 show 和 output:显示符号串和推理过程。五实验结果 公式正确 六实验总结 通过本次实验,使我更深入的理解了启发式搜索的原理以及实现,对于其优越性有一定认识,加深了对语法分析以及逻辑公式理解,同时熟练掌握了对树的操作。在编程实现过程中出现过不少问题,通过一次次调试得以解决,并一定程度上提高了我的编程能力,而且让我对人工智能这一课程有了更直接的认知。王浩算法源代码清单:#include#include#include#define MAX_L 5 int i=0;int stepcount=1;e
7、num typeand,or,detrusion,equal,level,variable;struct nodechar*s;type kind;int polar;node*next;node*child;int start;struct stepstep*child;step*brother;node*lhead;node*rhead;int count;char name30;int inite(char*s,node*head)int len=strlen(s);int j=0,polar=1;node*now=NULL;node*last=NULL;if(s=NULL)return
8、 0;last=head;while(ilen)if(si=|)if(!(si+1=A|si+1=a)&si+1!=1&si+1!=0&si+1!=(&si+1!=!|i=0)return 0;now=(node*)malloc(sizeof(node);now-kind=or;now-s=NULL;now-next=NULL;now-child=NULL;now-polar=polar;now-start=0;if(last-kind=level&last-child=NULL)last-child=now;elselast-next=now;last=now;i+;else if(si=&
9、)if(!(si+1=A|si+1=a)&si+1!=1&si+1!=0&si+1!=(&si+1!=!|i=0)return 0;now=(node*)malloc(sizeof(node);now-kind=and;now-s=NULL;now-next=NULL;now-child=NULL;now-polar=polar;now-start=0;if(last-kind=level&last-child=NULL)last-child=now;else last-next=now;last=now;i+;else if(si=!)if(!(si+1=A|si+1=a)&si+1!=1&
10、si+1!=0&si+1!=(&si+1!=!)return 0;polar=1-polar;i+;else if(si=-)if(si+1!=|(si+2!=!&si+2!=(&!(si+2=A|si+2=a)|i=0)return 0;now=(node*)malloc(sizeof(node);now-kind=detrusion;now-s=NULL;now-next=NULL;now-child=NULL;now-polar=polar;now-start=0;if(last-kind=level&last-child=NULL)last-child=now;else last-ne
11、xt=now;last=now;i=i+2;else if(si=)|(si+3!=!&si+3!=(&!(si+3=A|si+3=a)|i=0)&si+3!=1&si+3!=0)return 0;now=(node*)malloc(sizeof(node);now-kind=equal;now-s=NULL;now-next=NULL;now-child=NULL;now-polar=polar;now-start=0;if(last-kind=level&last-child=NULL)last-child=now;else last-next=now;last=now;i=i+3;els
12、e if(si=A|si=a)now=(node*)malloc(sizeof(node);now-kind=variable;now-next=NULL;now-child=NULL;now-polar=polar;now-start=0;now-s=(char*)malloc(MAX_L*sizeof(char);if(last-kind=level&last-child=NULL)last-child=now;else last-next=now;last=now;j=0;while(si=A|si=a)|(si=0)(now-s)j=si;i+;j+;if(si!=|&si!=&si!
13、=-&si!=s)j=0;polar=1;else if(si=1|si=0)if(si+1!=kind=equal;now-s=(char*)malloc(2*sizeof(char);(now-s)0=si;(now-s)1=0;now-next=NULL;now-child=NULL;now-polar=polar;now-start=0;if(last-kind=level&last-child=NULL)last-child=now;else last-next=now;last=now;i+;else if(si=()if(!(si+1=A|si+1=a)&si+1!=1&si+1
14、!=0&si+1!=!&si+1!=()return 0;now=(node*)malloc(sizeof(node);now-kind=level;now-s=NULL;now-next=NULL;now-child=NULL;now-polar=polar;now-start=0;if(last-kind=level&last-child=NULL)last-child=now;else last-next=now;last=now;i+;polar=1;if(!inite(s,last)return 0;else if(si=)if(si+1!=P&si+1!=1&si+1!=0&si+
15、1!=-&si+1!=kind=parent-kind;son-polar=parent-polar;son-s=parent-s;son-start=parent-start;if(parent-next!=NULL)son-next=clone(parent-next);else son-next=NULL;if(parent-child!=NULL)son-child=clone(parent-child);else son-child=NULL;return son;void remove(node*head)node*now=NULL;now=head;if(now=NULL)ret
16、urn;if(now-kind=level&now-child-kind=variable&now-child-next=NULL)now-polar=(now-child-polar=now-polar);now-child-polar=1;while(now-kind=level&now-child-kind=level&now-child-next=NULL)now-polar=(now-polar=now-child-polar);now-child=now-child-child;if(now-next!=NULL)remove(now-next);if(now-child!=NUL
17、L)remove(now-child);void restruct(node*head)node*now=NULL;node*last=NULL;node*newone=NULL,*newtwo=NULL,*newthree=NULL,*newfour=NULL,*newnow=NULL;int order=1;while(orderchild;while(now!=NULL)if(now-kind=variable|now-kind=level)&order=1)if(now-next!=NULL&now-next-kind=and)newone=(node*)malloc(sizeof(n
18、ode);newone-child=NULL;newone-kind=level;newone-next=NULL;newone-polar=0;newone-s=NULL;newone-start=0;if(last-kind=level)last-child=newone;else last-next=newone;newone-next=now-next-next-next;newone-child=now;now-next-next-polar=1-now-next-next-polar;now-next-kind=detrusion;now-next-next-next=NULL;n
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 人工智能 实验 报告 26899
限制150内