启发式搜索算法解决八数码问题(c语言)

启发式搜索算法解决八数码问题(c语言)

ID:34096076

大小:108.00 KB

页数:9页

时间:2019-03-03

启发式搜索算法解决八数码问题(c语言)_第1页
启发式搜索算法解决八数码问题(c语言)_第2页
启发式搜索算法解决八数码问题(c语言)_第3页
启发式搜索算法解决八数码问题(c语言)_第4页
启发式搜索算法解决八数码问题(c语言)_第5页
资源描述:

《启发式搜索算法解决八数码问题(c语言)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、1、程序源代码#include#includestructnode{inta[3][3];//用二维数组存放8数码inthx;//函数h(x)的值,表示与目标状态的差距structnode*parent;//指向父结点的指针structnode*next;//指向链表中下一个结点的指针};//------------------hx函数-------------------//inthx(ints[3][3]){//函数说明:计算s与目标状态的差距值inti,j;inthx=0;intsg[3][3]

2、={1,2,3,8,0,4,7,6,5};for(i=0;i<3;i++)for(j=0;j<3;j++)if(s[i][j]!=sg[i][j])hx++;returnhx;}//-------------hx函数end----------------------////-------------extend扩展函数----------------//structnode*extend(node*ex){//函数说明:扩展ex指向的结点,并将扩展所得结点组成一条//单链表,head指向该链表首结点,并且作为返回值inti,j,m,n;/

3、/循环变量intt;//临时替换变量intflag=0;intx[3][3];//临时存放二维数组structnode*p,*q,*head;head=(node*)malloc(sizeof(node));//headp=head;q=head;head->next=NULL;//初始化for(i=0;i<3;i++)//找到二维数组中0的位置{for(j=0;j<3;j++)if(ex->a[i][j]==0){flag=1;break;}if(flag==1)break;}for(m=0;m<3;m++)//将ex->a赋给xfor

4、(n=0;n<3;n++)x[m][n]=ex->a[m][n];//根据0的位置的不同,对x进行相应的变换//情况1if(i-1>=0){t=x[i][j];x[i][j]=x[i-1][j];x[i-1][j]=t;flag=0;for(m=0;m<3;m++)//将x赋给afor(n=0;n<3;n++)if(x[m][n]==ex->parent->a[m][n])flag++;if(flag!=9){q=(node*)malloc(sizeof(node));for(m=0;m<3;m++)//将x赋给afor(n=0;n<3;

5、n++)q->a[m][n]=x[m][n];q->parent=ex;q->hx=hx(q->a);q->next=NULL;p->next=q;p=p->next;}}//情况2for(m=0;m<3;m++)//将ex->a重新赋给x,即还原xfor(n=0;n<3;n++)x[m][n]=ex->a[m][n];if(i+1<=2){t=x[i][j];x[i][j]=x[i+1][j];x[i+1][j]=t;flag=0;for(m=0;m<3;m++)for(n=0;n<3;n++)if(x[m][n]==ex->paren

6、t->a[m][n])flag++;if(flag!=9){q=(node*)malloc(sizeof(node));for(m=0;m<3;m++)//将x赋给afor(n=0;n<3;n++)q->a[m][n]=x[m][n];q->parent=ex;q->hx=hx(q->a);q->next=NULL;p->next=q;p=p->next;}}//情况3for(m=0;m<3;m++)//将ex->a重新赋给x,即还原xfor(n=0;n<3;n++)x[m][n]=ex->a[m][n];if(j-1>=0){t=x[i

7、][j];x[i][j]=x[i][j-1];x[i][j-1]=t;flag=0;for(m=0;m<3;m++)for(n=0;n<3;n++)if(x[m][n]==ex->parent->a[m][n])flag++;if(flag!=9){q=(node*)malloc(sizeof(node));for(m=0;m<3;m++)//将x赋给afor(n=0;n<3;n++)q->a[m][n]=x[m][n];q->parent=ex;q->hx=hx(q->a);q->next=NULL;p->next=q;p=p->nex

8、t;}}//情况4for(m=0;m<3;m++)//将ex->a重新赋给x,即还原xfor(n=0;n<3;n++)x[m][n]=ex->a[m][n];if(j+1<=2){t=x[i]

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

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

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