ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:78.91KB ,
资源ID:17817535      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/17817535.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(n皇后问题合集文档格式.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

n皇后问题合集文档格式.docx

1、 return true; * 回溯函数,搜索解空间 * param t public void Back(int t) / t表示搜索解空间树当前的深度。N代表解空间树的深度。 / if(tN)表示搜索到了叶子节点,结束此次回溯,否则根据限界条件向下搜索。 if (t N) for (i = 1;= N; for (int j = 1; j 10,就有点抽了/*结果前total行每行均为一种放法,表示第i行摆放皇后的列位置,第total+1行,输出total*/ #includestdlib.hint n,stack100; /存当前路径int total; /路径数 void make(i

2、nt l) /递归搜索以stackl为初结点的所有路径 int i,j; /子结点个数 if (l=n+1) total=total+1; /路径数+1 for(i=1;i=n;i+) printf(%-3d,stacki); /输出第i行皇后的列位置stacki n exit; /回溯(若试题仅要求一条路径,则exit改为halt即可) for (i=1;i+) stackl=i; /算符i作用于生成stackl-1产生子状态stackl; if (!att(l,i) make(l+1); /再无算符可用,回溯 int att(int l,int i) int k; for (k=1;kl;

3、k+) if (abs(l-k)=abs(stackk-i)|i=stackk) return 1; return 0;int main()N= scanf(%d,&n); total=0; /路径数初始化为0 make(1); /从结点1出发,递归搜索所有的路径%dn,total); system(pause 由回溯法的算法流程可以看出,除非边界条件设置不当而导致死循环外,回溯法一般是不会产生内存溢出的。但是,回溯法亦有其致命的弱点时间效率比数学解析法低。为了改善其时效,我们可以从下述几个方面考虑优化:1、递归时对尚待搜索的信息进行预处理,减少搜索量;2、尽可能减少分支(解答树的次数);3、

4、增加约束条件,使其在保证出解的前提下尽可能“苛刻”;4、在约束条件中设置限定搜索层次的槛值。淮阴工学院数据结构课程设计报告设计题目: 八 皇 后 系(院): 计 算 机 工 程 系 专 业: 信 息 安 全 班 级: 信 息 1 0 6 学生姓名: 叶 青 学 号: 1061303127 指导教师: 张亚红 寇海洲 胡荣林 夏森 学年学期: 2007 2008 学年 第 2 学期 2008 年 6 月 25 日设计任务书课题名称 八 皇 后设计目的1. 用c+语言平台将一个的棋盘上放上个皇后,使得每一个皇后既攻击不到另外七个皇后,也不被另外七个皇后所攻击的92种结构予以实现2. 通过这次课程设

5、计,提高自己的编程能力,熟悉c+的编程坏境,为以后的程序开发打下基础.实验环境1)系统要求:win98以上操作系统;2)语言平台:tc+或vc+6.0; 3)执行文件:八皇后.exe任务要求试编写程序实现将八个皇后放置在国际象棋棋盘的无冲突的位置上的算法,并给出所有的解。工作进度计划序号起止日期工 作 内 容12008.6.232008.6.24查阅相关内容22008.6.242008.6.25编写代码及实习报告32008.6.252008.6.26完善课程设计报告42008.6.262008.6.27答辩指导教师(签章): 2008 年 6 月 30 日 摘要: 八皇后问题要求在一个的棋盘上

6、放上个皇后,使得每一个皇后既攻击不到另外七个皇后,也不被另外七个皇后所攻击按照国际象棋的规则,一个皇后可以攻击与之处在同一行或同一列或同一斜线上的其他任何棋子因此,八皇后问题等于要求八个皇后中的任意两个不能被放在同一行或同一列或同一斜线上。而本课程设计本人的目的也是通过用c+语言平台将一个的棋盘上放上个皇后,使得每一个皇后既攻击不到另外七个皇后,也不被另外七个皇后所攻击的92种结构予以实现使用递归方法最终将其问题变得一目了然,更加易懂。关键词: 八皇后 ; c+ ; 递归法 目 录1. 课题综述 11. 1课题的来源及意义 11. 2 面对的问题 12. 需求分析 12. 1 涉及到的知识 1

7、2. 2 软硬件的需求 12. 3 功能需求 23. 概要设计 24. 详细设计和实现 24. 1 算法描述及详细流程图 24.1.1 算法描述 34.1.2 算法流程图 35. 代码编写及详细注释 46. 程序调试 76. 1调试过程、步骤及遇到的问题 77. 运行与测试 77.1运行演示 7总 结 9致 谢 10参考文献 11.1. 课题综述1. 1课题的来源及意义 八皇后问题是一个古老而著名的问题,该问题是十九世纪著名的数学家高斯1850年提出的。在国际象棋中,皇后是最有权利的一个棋子;只要别的棋子在它的同一行或同一列或同一斜线(正斜线或反斜线)上时,它就能把对方棋子吃掉。所以高斯提出了

8、一个问题:在8*8的格的国际象棋上摆放八个皇后,使其不能相互攻击,即任意两个皇后都不能处于同一列、同一行、或同一条斜线上面,问共有多少种解法。到了现代,随着计算机技术的飞速发展,这一古老而有趣的数学游戏问题也自然而然的被搬到了计算机上。运用所学计算机知识来试着解决这个问题是个锻炼和提高我自己编程能力和独立解决问题能力的好机会,可以使我增强信心,为我以后的编程开个好头,故我选择了这个有趣的课题。1. 2 面对的问题解决冲突问题:这个问题包括了行,列,两条对角线;列:规定每一列放一个皇后,不会造成列上的冲突;行:当第I行被某个皇后占领后,则同一行上的所有空格都不能再放皇后,要把以I为下标的标记置为

9、被占领状态;2) 使用数据结构的知识,用递归法解决问题。 2. 需求分析2. 1 涉及到的知识 本次课程设计中,用到的主要知识有:递归法的运用,for语句的灵活运用,数据结构中树知识的灵活运用、栈及数组的掌握。2. 2 软硬件的需求1)系统要求:2) 语言平台: 2. 3 功能需求 当运行程序时,在屏幕上显示每一种方法八个皇后的相对位置,要用比较直观 的界面显示。3. 概要设计本课件学生是用循环递归循环来实现的,分别一一测试了每一种摆法,并把它拥有的92种变化表现出来。在这个程序中,我的主要思路以及思想是这样的:1)解决冲突问题:对角线:对角线有两个方向。在这我把这两条对角线称为:主对角线和从

10、对角线。在同一对角线上的所有点(设下标为(i,j),要么(i+j)是常数,要么(i-j)是常数。因此,当第I个皇后占领了第J列后,要同时把以(i+j)、(i-j)为下标的标记置为被占领状态。2)数据结构的实现 而对于数据结构的实现,学生则是着重于:数组aI:a I表示第I个皇后放置的列;I的范围:1.8;对角线数组:bj(主对角线),cj(从对角线),根据程序的运行,去决定主从对角线是否放入皇后;4. 详细设计和实现4. 1 算法描述及详细流程图4.1.1 算法描述A、 数据初始化。B、 从n列开始摆放第n个皇后(因为这样便可以符合每一竖列一个皇后的要求),先测试当前位置(n,m)是否等于0(

11、未被占领)。如果是,摆放第n个皇后,并宣布占领(记得姚横列竖列斜列一起设置),接着进行递归;如果不是,测试下一个位置(n,m+1),但是如果当n8时,便打印出结果。E、输出函数我使用printf输出,运行形式为:第m种方法为:* * * * * * * * 4.1.2 算法流程图5. 代码编写及详细注释#include math.hiostream.h#define QUEENS 8int iCount = 0; /!记录解的序号的全局变量。int SiteQUEENS;记录皇后在各行上的放置位置的全局数组。void Queen(int n);递归求解的函数。void Output();/!输

12、出一个解。int IsValid(int n);判断第n个皇后放上去之后,是否有冲突。void main() /*-Main:主函数。-*/ system(title 叶青-递归算法八皇后问题 cout 八皇后的解法:endl;- Queen(0);从第0行开始递归试探。 getch();按任意键返回。 void Queen(int n) /*-Queen:递归放置第n个皇后,程序的核心!-*/ int i; if(n = QUEENS) /!参数n从0开始,等于8时便试出了一个解,将它输出并回溯。 Output(); return; for(i = 1 ;= QUEENS ; i+) /!n

13、还没到8,在第n行的各个行上依次试探。 Siten = i;在该行的第i行上放置皇后。 if(IsValid(n) /!如果放置没有冲突,就开始下一行的试探。 Queen(n + 1); int IsValid(int n) /*-IsValid:判断第n个皇后放上去之后,是否合法,即是否无冲突。-*/ for(i = 0 ; n ;将第n个皇后的位置依次于前面n1个皇后的位置比较。 if(Sitei = Siten) /!两个皇后在同一列上,返回0。 if(abs(Sitei - Siten) = (n - i) /!两个皇后在同一对角线上,返回0。 return 1;没有冲突,返回1。 v

14、oid Output()/*-Output:输出一个解,即一种没有冲突的放置方案。-*/ int i;No.%-5d , +iCount);输出序号。 QUEENS ; i+)/!依次输出各个行上的皇后的位置,即所在的列数。%d , Sitei);6. 程序调试6. 1调试过程、步骤及遇到的问题在完整程序调试时遇到几个小问题,后经细心改正后才把调试工作做完。例如:当用printf输出时,出现了一些错误,几经调试后,发现原来是缺少了stdio.h这样一个头文件,添加了头文件后, 还出现了一些问题,逻辑错误导致程序死循环或不循环或循环一小部分,但是编译时却没有错误,就是没有正确的输出答案,一开始我

15、也不知道是怎么回事,通过和同学的交流,发现是逻辑错误,经过改正后,程序终于可以运行了.7. 运行与测试 7.1运行演示总 结 通过了19周这个星期的程序设计,我从中得到了许多的经验以及软件设计的一些新的思路;从这个八皇后问题设计以及分析中,本人从中理解到了数据结构对于计算机软件设计的重要性,它的使用,可以改变一个软件的运行周期,也可以将软件的思路从繁化简,并且都能够通过数据结构的相关引导,将本身以前编程思想进行扩充,发展;这也是在这次课程设计中我所掌握得到的。 但由于我的基本知识还不是那么扎实,也缺乏对软件设计的经验,在这过程中也出现了一些问题,如,八皇后在变成初期由于没真正体会到数据结构中“

16、树”在里面的运用,将程序往大一时c语言的方向发展,不自觉的采用了非递归的算法,结果大大增加了程序的复杂程度。并且也让整个程序的时间复杂度变得更大;在后来学生对数据结构的第六章进行了比较深入的研读,才发现了数据结构树的实际运用的空间是相当的大,并且,通过了重温树的回溯,以及二叉树的遍历,最终将程序进行了一次较大的改造。并且通过思考,再将以前的数组知识加以运用才最终解决了这个问题,整个程序的算法的可看性也有了相当的改进。 课程设计随着时间的推移,也即将结束了,但这个学期数据结构的学习还是具有相当大的意义,它从一个程度上改变了我们的编程思想,如何将一个程序快速而又准备的进行编写,进行编译,都成为了我

17、们思考的重点,也通过这一个学期的学习,我们将数据结构的思想带入到了我们以后的编程学习中去。在这个阶段,我也明白了,好的思想,不能提留于字面上的认知,还需要的是平时多练多写一些相关的程序,并且通过修改,加入新的算法去尝试改变自己的一些编程思想。保持更新算法的速度,这才是关键。 课程设计已经接近尾声了,但它给我的不只是程序设计上的满足,更重要的是对自己编程思想的一次更新,以及对算法的一个全新的认识! 我觉得还可以考虑开发N皇后问题,在主界面中添加一个 int型的变量,程序一开始要求输入一个数(确定是几皇后问题),输入后按下 enter 后,输出各种解.主程序与八皇后的求解大体相同.致 谢 在这次课

18、程设计中,我遇到了不少问题,包括程序上的和课程设计的撰写上的,同学曾给过我许多帮助,在此我表示对他们的忠心感谢。同时,指导老师和实验人员给了我很多上机的机会,给了我一个做课程设计的很好的条件,我才能够顺利的完成,在此,我仅以文字的形式表示忠心感谢,感谢他们这么多天对我的帮助。 参考文献1 苏仕华,数据结构课程设计.-北京:机械工业出版社,2005.52 于永彦,赵建洋.课程设计指导书.淮安:江苏淮阴工学院 计算机工程系,20063 刘振安,刘燕君,孙忱. C+语言课程设计.北京:高等教育出版社,20034 陈志泊, 张海燕, 王春玲. Visual C+程序设计. 中国铁道出版社 ,20055

19、 吕凤哲,C+语言程序设计(第二版).北京:电子工业出版社,20056 殷人昆,陶永雷等.数据结构(用面向对象方法与C+ ).北京:清华大学出版社,19997 严蔚敏,吴伟民,数据结构北京:清华大学出版社,19978 李春葆.数据结构考研指导.北京:清华大学出版社,20029 陈慧南数据结构C+语言描述北京:人民邮电出版社,200503指导教师评语学号1061303127姓名叶 青班级信 息106选题八 皇 后评价内容权重(%)得分考勤记录、学习态度、工作作风与表现。5自学情况:上网检索机时数、文献阅读情况(笔记)。10论文选题是否先进,是否具有前沿性或前瞻性。成果验收:是否完成设计任务;能否运行、可操作性如何等。20报告的格式规范程度、是否图文并茂、语言规范及流畅程度;主题是否鲜明、重心是否突出、论述是否充分、结论是否正确;是否提出了自己的独到见解。306文献引用是否合理、充分、真实。7答辩情况: 自我陈述、回答问题的正确性、用语准确性、逻辑思维、是否具有独到见解等。25合计 2008 年 6 月 30 日

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1