八皇后数据结构实验报告 完整版_第1页
八皇后数据结构实验报告 完整版_第2页
八皇后数据结构实验报告 完整版_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数据结构实验报告——八皇后问题实验目的:熟练掌握栈操作的基本算法实现。实现功能:利用回溯法和栈来实现八皇后问题:在8×8的国际象棋棋盘上,安放8个皇后,要求没有一个皇后能够“吃掉”任何其他一个皇后,即没有两个或两个以上的皇后占据棋盘上的同一行、同一列或同一对角线。设计思路:数据结构:enumboolean{false,true}enumbooleana[9],b[17],c[17];//检查皇后之间是否冲突//皇后位置安全性可用逻辑表达式:a[j]&&b[i+j]&&c[i-j+9]ints[9];//s[1..8]表示顺序栈,栈的下标值表示皇后所在的行号,栈的内容是皇后所在的列号。 该算法抽象描述如下:置当前行当前列均为1;while(当前行号≤8){检查当前行,从当前列起逐列试探,寻找安全列号;if(找到安全列号)放置皇后,将列号记入栈中,并将下一行置成当前行,第一列置为当前列;else退栈回溯到上一行,移去该行已放置的皇后,以该皇后所在列的下一列作为当前列;}结束程序。程序流程图:源程序:#include<stdio.h>enumboolean{FALSE,TRUE};//声明全局变量enumbooleana[9],b[17],c[17];ints[9];intnum=0;//函数声明voidprint();voidmovequeen();voideightqueen();voidmain(){//主函数eightqueen();printf("共有%d种解法\n",num);}voidprint()//输出函数{ intk; printf("\n"); printf("NO.%d\n",++num); printf("行号:12345678\n"); printf("列号:"); for(k=1;k<=8;k++) printf("%3d",s[k]);printf("\n");}voidmovequeen(inti,intj){ a[j]=TRUE;b[i+j]=TRUE;c[i-j+9]=TRUE;}voideightqueen()//算法函数{ inti,j; for(i=2;i<=16;i++){ if(i>=2&&i<=9) a[i-1]=TRUE; b[i]=TRUE;c[i]=TRUE; }i=1;j=1; while(i>=1){ while(j<=8){ if(a[j]&&b[i+j]&&c[i-j+9]) break; j++; } if(j<=8){ a[j]=FALSE;b[i+j]=FALSE; c[i-j+9]=FALSE; s[i]=j; if(i==8){ num++;print(); movequeen(i,j); i--;j=s[i]; movequeen(i,j); j++; } else{i++;j=1;} } else{i--; if(i>=1){ j=s[i]; movequeen(i,j);j++;}} }}实验心得:通过本次实验大大的提高了我个人的动手能力,对VC编程更加的熟练,这个程序也一定程度的锻炼了我的

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论