实验二八皇后问题(附件).doc

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
2009级数据结构实验报告 实验名称: 实验二 栈和队列 学生姓名: 班 级: 班内序号: 学 号: 日 期: 一、实验要求 1.实验目的: 进一步掌握指针、模板类、异常处理的使用; 掌握栈的操作的实现方法; 掌握队列的操作的实现方法; 培养使用栈解决实际温特的能力; 培养使用队列解决实际问题的能力; 2.实验内容 利用栈结构是八皇后问题。 八皇后问题:在8X8的棋盘上放置8个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列、同一斜线上。 3.代码要求 必须有异常处理,保持良好的编程风格,递归程序注意调用的过程,防止栈溢出。 二、程序分析 1.创建棋盘 const int MAXSIZE = 8;//棋盘大小 int chess[MAXSIZE][MAXSIZE]={0}; int row; int col; 2解决个行、列、对角线上是否有皇后的方法 int Solve() { stackNode stack; int col[MAXSIZE] = {0}, md[2 * MAXSIZE - 1] = {0}, sd[2 * MAXSIZE - 1] = {0}; //互斥标志,表示同一列及对角线上是否有皇后, int str, stc, i,j; int scount = 0; Node topNode; for(i = 0; i MAXSIZE; i++) { topNode.row = 0; topNode.col = MAXSIZE - 1 - i; topNode.isMarked = false; stack.push(topNode); } 以行为单位回溯 while(!stack.empty()) { topNode = stack.top(); str = topNode.row; stc = topNode.col; if(topNode.isMarked==false) {// 如果栈顶元素的位置并没有确立 if(col[stc] || md[str - stc + MAXSIZE - 1] || sd[str + stc]) {//如果同一列或同一对角线上已有皇后,则退回*/ stack.pop(); } else { //占据这个位置,设置列、对角线上的互斥标志 col[stc] = 1; md[str - stc + MAXSIZE - 1] = 1; sd[str + stc] = 1; //标记栈顶元素的isMarked 值 topNode.isMarked = true; stack.pop(); stack.push(topNode); chess[str][stc] = 1;//标记棋盘对应位置 if(str == MAXSIZE - 1) {// 如果此时已经到达最后一行,则表示此种布局方法是成功的,输出相关信息 coutA solution is:endl; for(i=0;iMAXSIZE;++i) { for(j=0;jMAXSIZE;++j) { if(chess[i][j]==1) { cout(i+1,j+1); } } } cou

您可能关注的文档

文档评论(0)

xuefei111 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档