电脑桌面
添加小米粒文库到电脑桌面
安装后可以在桌面快捷访问

C语言实现8数码问题

C语言实现8数码问题_第1页
1/13
C语言实现8数码问题_第2页
2/13
C语言实现8数码问题_第3页
3/13
1、 实验目的 (1)熟悉人工智能系统中的问题求解过程; (2)熟悉状态空间中的盲目搜索策略; (3)掌握盲目搜索算法,重点是宽度优先搜索和深度优先搜索算法。 2、 实验要求 用 VC 语言编程,采用宽度优先搜索和深度优先搜索方法,求解8 数码问题 3、 实验内容 (1)采用宽度优先算法,运行程序,要求输入初始状态 假设给定如下初始状态 S0 2 8 3 1 6 4 7 0 5 和目标状态 Sg 2 1 6 4 0 8 7 5 3 验证程序的输出结果,写出心得体会。 (2)对代码进行修改(选作),实现深度优先搜索求解该问题 提示:每次选扩展节点时,从数组的最后一个生成的节点开始找,找一个没有被扩展的节点。这样也需要对节点添加一个是否被扩展过的标志。 4 源代码及实验结果截图 #include #include #include //八数码状态对应的节点结构体 struct Node{ int s[3][3];//保存八数码状态,0 代表空格 int f,g;//启发函数中的f 和g 值 struct Node * next; struct Node *previous;//保存其父节点 }; int open_N=0; //记录Open 列表中节点数目 //八数码初始状态 int inital_s[3][3]={ 2,8,3,1,6,4,7,0,5 }; //八数码目标状态 int final_s[3][3]={ 2,1,6,4,0,8,7,5,3 }; //------------------------------------------------------------------------ //添加节点函数入口,方法:通过插入排序向指定表添加 //------------------------------------------------------------------------ void Add_Node( struct Node *head, struct Node *p) { struct Node *q; if(head->next)//考虑链表为空 { q = head->next; if(p->f < head->next->f){//考虑插入的节点值比链表的第一个节点值小 p->next = head->next; head->next = p; } else { while(q->next)//考虑插入节点x,形如a<= x <=b { if((q->f < p->f ||q->f == p->f) && (q->next->f > p->f || q->next->f == p->f)){ p->next = q->next; q->next = p; break; } q = q->next; } if(q->next == NULL) //考虑插入的节点值比链表最后一个元素的值更大 q->next = p; } } else head->next = p; } //------------------------------------------------------------------------ //删除节点函数入口 //-------------------------------------------...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。
3、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。

碎片内容

C语言实现8数码问题

确认删除?
VIP
微信客服
  • 扫码咨询
会员Q群
  • 会员专属群点击这里加入QQ群
客服邮箱
回到顶部