首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读下列说明和C代码,回答问题,将解答写在答题纸的对应栏内。 【说明】 n皇后问题描述为:在一个n×n的棋盘上摆放n个皇后,要求任意两个皇后不能冲突,即任意两个皇后不在同一行、同一列或者同一斜线上。 算法的基本思想如下: 将第i个皇
阅读下列说明和C代码,回答问题,将解答写在答题纸的对应栏内。 【说明】 n皇后问题描述为:在一个n×n的棋盘上摆放n个皇后,要求任意两个皇后不能冲突,即任意两个皇后不在同一行、同一列或者同一斜线上。 算法的基本思想如下: 将第i个皇
admin
2021-03-13
25
问题
阅读下列说明和C代码,回答问题,将解答写在答题纸的对应栏内。
【说明】
n皇后问题描述为:在一个n×n的棋盘上摆放n个皇后,要求任意两个皇后不能冲突,即任意两个皇后不在同一行、同一列或者同一斜线上。
算法的基本思想如下:
将第i个皇后摆放在第i行,i从1开始,每个皇后都从第1列开始尝试。尝试时判断在该列摆放皇后是否与前面的皇后有冲突,如果没有冲突,则在该列摆放皇后,并考虑摆放下一个皇后;如果有冲突,则考虑下一列。如果该行没有合适的位置,回溯到上一个皇后,考虑在原来位置的下一个位置上继续尝试摆放皇后……直到找到所有合理摆放方案。
【C代码】
下面是算法的C语言实现。
(1)常量和变量说明
n:皇后数,棋盘规模为n×n
queen[]:皇后的摆放位置数组,queen
表示第i个皇后的位置,1≤queen
≤n
(2)C程序
#include
#define n 4
int queen[n+1];
void Show(){ /* 输出所有皇后摆放方案*/
int i;
printf("(");
for(i=1;i<=n;i++){
printf(" %d",(queen
);
}
printf(")\n");
}
int Place(int j){ /*检查当前列能否放置皇后,不能放返回0,能放返回1*/
int i;
for(i=1;i
if( (1)________ || abs(queen
-queen[j])==(j-i)){
return 0;
}
}
return(2)________;
}
void Nqueen(int j){
int i;
for(i=1;i<=n;i++){
queen[j]=i;
if( (3)________ ){
if(j==n){ /*如果所有皇后都摆放好,则输出当前摆放方案*/
Show()
}else{ /*否则继续摆放下一个皇后*/
(4)________;
}
}
}
}
int main(){
Nqueen(1);
return 0;
}
当n=4时,有(6)________种摆放方式,分别为(7)________。
选项
答案
(6)2 (7)(2,4,1,3)或(2 4 1 3) (3,1,4,2)或(3 1 4 2)
解析
根据对问题的描述和C语言实现,可以摆放皇后获得问题的解。当n=4时,有两种摆放方案,如下图所示,其中◇表示皇后。因此(6)中填2,(7)中填(2,4,1,3)和1(3,1,4,2)。
本题考查算法设计策略与分析方法。
此类题目要求考生认真阅读题目对问题的描述,以及用算法求解该问题的思路,能够理解如何将典型的算法设计策略应用到实际问题的求解中,并用某种程序设计语言来实现。
转载请注明原文地址:https://kaotiyun.com/show/KsxZ777K
本试题收录于:
软件设计师下午应用技术考试题库软考中级分类
0
软件设计师下午应用技术考试
软考中级
相关试题推荐
造成故障1的原因是什么?如何解决?1.将故障2中(1)和(2)两处合适的答案填入相应的解答栏内。2.故障2如何解决?
阅读以下说明,回答问题1、问题2、问题3和问题4,将解答填入对应栏内。[说明]某公司想建立一个Intranet,建立FTP服务器、DNS服务器、Email服务器、Web服务器和内部业务服务器,同时其他部门的工作人员也要联网,要求这些机器有的
阅读以下说明,回答问题1、问题2、问题3、问题4和问题5,将解答填入对应栏内。[说明]CableModem可以作为一个网桥直接与用户相连,也可以作为一个路由器与Hub相连,从经济角度考虑,目前采用后一种方式居多。有一种HFC网络如图6-2
设计该宽带路由器的多任务嵌入式实时操作系统时,由于多个任务均可能要求占用CPU这个关键资源,因此CPU的任务管理是一个非常重要的设计内容。在该实时操作系统中,任务作为占用资源的基本单位,总共有5个状态:休眠状态、就绪状态、运行状态、等待或挂起状态和中断服务
设计该宽带路由器的多任务嵌入式实时操作系统时,由于多个任务均可能要求占用CPU这个关键资源,因此CPU的任务管理是一个非常重要的设计内容。在该实时操作系统中,任务作为占用资源的基本单位,总共有5个状态:休眠状态、就绪状态、运行状态、等待或挂起状态和中断服务
设计该宽带路由器的多任务嵌入式实时操作系统时,由于多个任务均可能要求占用CPU这个关键资源,因此CPU的任务管理是一个非常重要的设计内容。在该实时操作系统中,任务作为占用资源的基本单位,总共有5个状态:休眠状态、就绪状态、运行状态、等待或挂起状态和中断服务
随着Internet的发展,用户对网络带宽的要求不断提高,传统的接入网已成为整个网络中的瓶颈,以新的宽带接入技术取而代之已成为目前研究的焦点。其中最引人注意的是光纤接入技术。
随机试题
小儿示指络脉色青,主
女孩9岁,多动,上课时注意力不集中,平时有冲动性行为,学习成绩下降。诊断为多动性障碍(注意力缺陷多动症),以前曾用苯巴比妥治疗,症状未见改善,反而加剧。在用匹莫林治疗过程中要进行那些实验室检查
税法规定财产转让所得适用比例税,其税率为()
审计业务约定书一般包括的基本内容有()。
期货业协会的权力机构为()。
阅读下面一首诗,按要求回答问题。裴给事宅白牡丹裴潾长安豪贵惜春残,争赏街西紫牡丹。别有玉盘承露冷,无人起就月中看。[注](《唐国史补》)牡丹中以大红大紫为贵,白色牡丹不受重视。
军衔:将军
下列规范性文件中,属于宪法相关法的是()(2016年非法学综合课单选第15题)
电子支付主要是依靠电子货币的流通来实现,请说出电子货币的三种主要形态是什么?用户在飞腾游戏网站购买游戏装备使用的游戏币属于哪一种电子货币形态?飞腾游戏网站除了有为用户提供在线购买游戏币服务的Web服务器外,还有许多游戏服务器,其内部数据的安全性非常重要
在考生文件夹下,打开文档WORD.DOCX,按照要求完成下列操作并以该文件名(WORD.DOCX)保存文档。【文档开始】盐的世界我国青海有个著名的柴达木盆地。它的总面积34万平方公里。这里有水草丰美的牧场,土壤肥沃的农田,奔腾
最新回复
(
0
)