八皇后问题的解决完整

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

淮阴工学院

数据结构课程设计报告

设计题目:八皇后

2008 年 6 月25 日

设计任务书

摘要:

八皇后问题要求在一个8*8的棋盘上放上8个皇后,使得每一个皇后既攻击不到另外七个皇后,也不被另外七个皇后所攻击.按照国际象棋的规则,一个皇后可以攻击与之处在同一行或同一列或同一斜线上的其他任何棋子.因此,八皇后问题等于要求八个皇后中的任意两个不能被放在同一行或同一列或同一斜线上。

而本课程设计本人的目的也是通过用c++语言平台将一个8*8的棋盘上放上8个皇后,使得每一个皇后既攻击不到另外七个皇后,也不被另外七个皇后所攻击的92种结构予以实现.?使用递归方法最终将其问题变得一目了然,更加易懂。

关键词:八皇后 ; c++ ; 递归法

目录

.

1. 课题综述

1. 1课题的来源及意义

八皇后问题是一个古老而着名的问题,该问题是十九世纪着名的数学家高斯1850年提出的。

在国际象棋中,皇后是最有权利的一个棋子;只要别的棋子在它的同一行或同一列或同一斜线(正斜线或反斜线)上时,它就能把对方棋子吃掉。

所以高斯提出了一个问题:在8*8的格的国际象棋上摆放八个皇后,使其不能相互攻击,即任意两个皇后都不能处于同一列、同一行、或同一条斜线上面,问共有多少种解法。

到了现代,随着计算机技术的飞速发展,这一古老而有趣的数学游戏问题也自然而然的被搬到了计算机上。运用所学计算机知识来试着解决这个问题是个锻炼和提高我自己编程能力和独立解决问题能力的好机会,可以使我增强信心,为我以后的编程开个好头,故我选择了这个有趣的课题。

1. 2 面对的问题

1)???解决冲突问题:

这个问题包括了行,列,两条对角线;

列:规定每一列放一个皇后,不会造成列上的冲突;

行:当第I行被某个皇后占领后,则同一行上的所有空格都不能再放皇后,要把以I为下标的标记置为被占领状态;

2)使用数据结构的知识,用递归法解决问题。

2. 需求分析

2. 1 涉及到的知识

本次课程设计中,用到的主要知识有:递归法的运用,for语句的灵活运用,数据结构中树知识的灵活运用、栈及数组的掌握。

2. 2 软硬件的需求

1)系统要求:win98以上操作系统;

2) 语言平台:tc++或vc++;

2. 3 功能需求

当运行程序时,在屏幕上显示每一种方法八个皇后的相对位置,要用比较直观的界面显示。

3. 概要设计

本课件学生是用循环递归循环来实现的,分别一一测试了每一种摆法,并把它拥有的92种变化表现出来。在这个程序中,我的主要思路以及思想是这样的:

1)解决冲突问题:

这个问题包括了行,列,两条对角线;

列:规定每一列放一个皇后,不会造成列上的冲突;

行:当第I行被某个皇后占领后,则同一行上的所有空格都不能再放皇后,要把以I为下标的标记置为被占领状态;

对角线:对角线有两个方向。在这我把这两条对角线称为:主对角线和从对角线。在同一对角线上的所有点(设下标为(i,j)),要么(i+j)是常数,要么(i-j)是常数。因此,当第I个皇后占领了第J列后,要同时把以(i+j)、(i-j)为下标的标记置为被占领状态。

2)数据结构的实现

而对于数据结构的实现,学生则是着重于:

数组a[I]:a [I]表示第I个皇后放置的列;I的范围:1..8;

对角线数组:b[j](主对角线),c[j](从对角线),根据程序的运行,去决定主从对角线是否放入皇后;

4. 详细设计和实现

4. 1 算法描述及详细流程图

算法描述

A、数据初始化。

B、从n列开始摆放第n个皇后(因为这样便可以符合每一竖列一个皇

后的要求),先测试当前位置(n,m)是否等于0(未被占领)。如果是,摆放

第n个皇后,并宣布占领(记得姚横列竖列斜列一起设置),接着进行递归;

如果不是,测试下一个位置(n,m+1),但是如果当n<=8,m=8时,发现此时已无法摆放时,便要进行回溯。从问题的某一种可能出发,搜索从这种情况能出发,继续搜索,这种不断“回溯”的寻找解的方法,称为“回溯法”。

C、使用数组实现回溯法的思想。

D、当n>8时,便打印出结果。

E、输出函数我使用printf输出,运行形式为:第m种方法为:* * * *

* * * *

算法流程图

5. 代码编写及详细注释

#include <>

#include <>

#include <>

#include <>

#include <>

#define QUEENS 8

int iCount = 0; -5d" , ++iCount); 程序调试

6. 1调试过程、步骤及遇到的问题

在完整程序调试时遇到几个小问题,后经细心改正后才把调试工作做完。

例如:当用printf输出时,出现了一些错误,几经调试后,发现原来是缺少了这样一个头文件,添加了头文件后, 还出现了一些问题,逻辑错误导致程序死循环或不循环或循环一小部分,但是编译时却没有错误,就是没有正确的输出答案,一开始我也不知道是怎么回事,通过和同学的交流,发现是逻辑错误,经过改正后,程序终于可以运行了.

7. 运行与测试

运行演示

总结

通过了19周这个星期的程序设计,我从中得到了许多的经验以及软件设

计的一些新的思路;从这个八皇后问题设计以及分析中,本人从中理解到了数

据结构对于计算机软件设计的重要性,它的使用,可以改变一个软件的运行周期,也可以将软件的思路从繁化简,并且都能够通过数据结构的相关引导,将

本身以前编程思想进行扩充,发展;这也是在这次课程设计中我所掌握得到的。

但由于我的基本知识还不是那么扎实,也缺乏对软件设计的经验,在这过

程中也出现了一些问题,如,八皇后在变成初期由于没真正体会到数据结构中“树”在里面的运用,将程序往大一时c语言的方向发展,不自觉的采用了非

递归的算法,结果大大增加了程序的复杂程度。并且也让整个程序的时间复杂

度变得更大;在后来学生对数据结构的第六章进行了比较深入的研读,才发现

相关文档
最新文档