版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1、程序源代码 include #include struct node int a33;用二维数组存放8数码 int hx;/函数h (x)的值,表示与目标状态的差距 struct node *parent;/指向父结点的指针 struct node *next;/指向链表中F个结点的指针 ; /hx 函数/ int hx(int s33) /函数说明:计算S与目标状态的差距值 int i, j; int hx=0; int sg3 3 = 1,2 3,8,0,4, 7, 6, 5; for(i=0;i3;i+) for(j=0;jnext=NULL; /初始化 for(i=0;i3;i+)
2、/找到二维数组中0的位宜 for(j=0;jalij=0) flag=l; break; if(flag=l) break; for (m=0: ma 赋给 x for (n=0;namLn; 根据0的位宜的不同,对X进行相应的变换 情况1 if(i-l=0) t=xij ;xi j二xi-1 j ;Xi-lj=t; flag=0; for (m=0; m3: m+) /将 x 赋给 a for(n=0;nparent-amLn) flag 卄; if(flag!=9) q=(node *)malloc(sizeof(node); for (m=0;m3;m-r+) /将 x 赋给 a for
3、(n=0;namn二xm n; q-parent=ex; q-hx二hx(q-a); q-next=NULL; p-next=q; p=p-next; 情况2 for (m=0;ma 重新赋给 x,即还原 x for (n=0;namn; if(i+l=2) t二xi j ;xi j二xi+l j ;xi+l j二t; flagO; for(m=0;m3;m+) for (n=0;nparentamLn) flag 卄; if (flag!=9) q=(node *)malloc(sizeof(node); for (m=0;m3;m+) /将 x 賦给 a for (n=0;nam n=xm
4、 n; q-parent=ex; q-hx二hx(q-a); q-next=NULL; p-next=q; p=p-next; 情况3 for (m=0;ma 重新赋给 x,即还原 x for (n=0;namn; if(j-l=0) t=xi j ;xi j二xi j-l ;Xi j-l=t; flag=0; for(m=0;m3;m+) for (n=0;nparentamn) flag 卄; if(flag!=9) q二(node *)malloc(sizeof(node); for (m=0;m3;m+)/将 x 赋给 a for(n=0;namn=xmn; q-parent=ex;
5、q-hx二hx(q-a); q-next=NULL; p-next=q; p=p-next; 情况4 for (m=0;ma 重新赋给 x,即还原 x for (n=0;namn; if(j+l=2) t=xi j ;xi j二xi j+1 ;xij+l=t; flag=0; for(m=0;m3;m+) for (n=0;nparent-amn) flag 卄; if (flag!=9) q=(node *)malloc(sizeof(node); for (m=0;m3;m-r+) for (n=0;namn二xmn; q-parent=ex; q-hx二hx(q-a); q-next=N
6、ULL; p-next=q; p=p-next; head=head-next; return head; /extend 函数 end /insert 函数/ node* insert(node *open, node * head) /函数说明:将head链表的结点依次插入到。pm链表相应的位置, /使open表中的结点按从小到大排序。函数返回open指针 node *q;/p、q均指向open表中的结点,p指向q所指的前一个结点 int i, j; int flag=0; 辻(open二二NULL)/初始状态,open表为空 /首先将head表第一个结点直接放入open表中 open=h
7、ead; q=head; head二head-next; q-next=NULL; 再插入第二个结点 if (head-hxhx) /插入到首结点位置 open=head; head=head-next; open-next=q; else 或者第二个结点的位置 q-next=head; head=head-next; q=q-next; q-next=NULL; p=open; p二open; q=open-next; /end if wh 订e(head!=NULL) q=open; if (head-hxhx) /插入到表头 open=head; head=head-next; open
8、-next=q; continue; else q=q-next;p=open; /否则,q指像第二个结点,p指向q前一个结点 while (q-next! =NULL) /将head的一个结点插入到链表中(非表尾的位置) if(q-hxhx) q二q_next; p=p-next; else p-next=head; head=head-next; p-next-next=q; break; if (q-next=NULL)/将head的一个结点插入到表尾 if(q-hxhead-hx) p-next=head; head=head-next; p-next-next=q; else q-n
9、ext=head; head=head-next; q-next-next=NULL; /if /wh 订 e return open; /insert /insert 函数 end/ OHMWMM void mainO int i, j; node sO; node *open, *close; node *p,*q; node *newlist; printfC请输入初始状态的8数码(按每行从左往右依次输入,用0表示空格):); for(i=0;i3;i +) for(j=0;jhx二9; =hx; open二 p= if (open-hx=0) printf (该状态已为最终状态! n)
10、; return; q= close二 open二NULL; newlist=extend(q) ;/newlist指向新扩展出来的链表 open=insert (open, newlist);/将扩展岀来的结点插入到open表中 wh 订 e(l) q-next=open;/q始终指向close表尾结点。将open表的第一个元素加到close 表 open=open-next; q=q-next; q-next=NULL; if (q-hx=0) printf (n 搜索成功! n); break; newlist=extend(q) ;/对close表最后一个结点进行扩展,扩展得到的链表接到 open表尾 open=insert (open, newlist) ;/将扩展的结点按顺序插入到open表中p=close; printfC择优搜索过程如下:n); while(p!=NULL) for(i=0;i3;i+)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024-2025学年四川现代职业学院单招《语文》预测复习AB卷附答案详解
- 冷冻物流营销方案(3篇)
- 砼固化施工方案(3篇)
- 低温冻伤应急预案(3篇)
- 书法活动策划方案案例(3篇)
- 2026年阿勒泰职业技术学院单招职业倾向性测试题库附参考答案详解(综合卷)
- 2026年陕西省延安市单招职业倾向性测试题库及一套参考答案详解
- 2026年陕西职业技术学院单招职业适应性测试题库及参考答案详解
- 关于牛姓氏研究报告
- 2026年青岛恒星科技学院单招职业技能考试题库附参考答案详解(综合卷)
- 某高校污水与中水回用工程方案设计
- 青光眼防控与干预策略-全面剖析
- DB31T 1545-2025卫生健康数据分类分级要求
- 2025年部编版道德与法治五年级下册第一单元复习课教案
- DB37T3418-2018标准化池塘建设改造技术规范
- ICU常见管道护理培训课件
- 一年级综合课教案18篇
- 《农业机械化》课件
- 铁路劳动安全 课件 第三章 防洪抢险
- 2024年度卫星导航设备融资租赁合同
- 基于PLC的物料分拣系统设计
评论
0/150
提交评论