- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
您可能关注的文档
- 嵌入式Linux下C++程序设计--02-1数组,指针,引用,内存分配,命名空间详解.ppt
- 嵌入式操作系统设计1详解.ppt
- 嵌入式交叉编译环境详解.ppt
- 嵌入式期末考试重点整理幻灯片.docx
- 嵌入式软件开发环境详解.ppt
- 嵌入式数字硬盘录像机常见问题处理(附件).doc
- 嵌入式网络协议攻略(附件).doc
- 嵌入式系统复习资料(附件).doc
- 嵌入式系统复习总结(附件).doc
- 嵌入式系统和浏览器在机顶盒中的应用(附件).doc
- 国际标准 IEC 60939-2-2:2004 EN_D Complete filter units for radio interference suppression - Part 2-2: Blank detail specification - Passive filter uits for electromagnetic interference suppression - Filters for which safety tests are required (safety.pdf
- 国际标准 IEC 60670-23:2006 EN-FR Boxes and enclosures for electrical accessories for household and similar fixed electrical installations - Part 23: Particular requirements for floor boxes and enclosures 家用和类似固定电气安装用电器配件的盒子与封闭装置——第23部分:地板箱和封闭装置的要求.pdf
- 国际标准 IEC 60670-23:2006 EN-FR 家用和类似固定电气安装用电器配件的盒子与封闭装置——第23部分:地板箱和封闭装置的要求 Boxes and enclosures for electrical accessories for household and similar fixed electrical installations - Part 23: Particular requirements for floor boxes and enclosures.pdf
- 2024版完整的货物运输合同书.doc
- 2024版无财产的离婚协议书书模板.doc
- 2024版委托融资租赁合同书书.doc
- 2024版汪怡的离婚协议书书.doc
- 2024版委托活动代理服务协议书书.doc
- 2024版挖掘机租赁合同书范本最新.doc
- 2024版退款协议书书.doc
文档评论(0)