- 26
- 0
- 约7.21千字
- 约 8页
- 2017-09-27 发布于北京
- 举报
例15:N皇后问题
在N*N的棋盘上放置N个皇后而彼此不受攻击(即在棋盘的任一行,任一列和任一对角线上不能放置2个皇后),编程求解所有的摆放方法。
分析:
由于皇后的摆放位置不能通过某种公式来确定,因此对于每个皇后的摆放位置都要进行试探和纠正,这就是“回溯”的思想。在N个皇后未放置完成前,摆放第I个皇后和第I+1个皇后的试探方法是相同的,因此完全可以采用递归的方法来处理。
下面是放置第I个皇后的的递归算法:
Procedure Try(I:integer);
{搜索第I行皇后的位置}
var
j:integer;
begin
if I=n+1 then 输出方案;
for j:=1 to n do
if 皇后能放在第I行第J列的位置 then begin
放置第I个皇后;
对放置皇后的位置进行标记;
Try(I+1)
对放置皇后的位置释放标记;
End;
End;
N皇后问题的递归算法的程序如下:
program N_Queens;
const
MaxN = 100; {最多皇后数}
var
A:array [1..MaxN] of Boolean; {竖线被控制标记}
B:array [2..MaxN * 2] of Bo
您可能关注的文档
最近下载
- 2025年湖南省中考数学真题试卷(含答案).pdf VIP
- 2025年上海市英语高考二轮热点专题复习GVC语法、词汇、完形组合练01.docx VIP
- 2022年北京市中考物理试卷 - 答案.docx VIP
- 标准图集-12J609防火门窗图集.pdf VIP
- 移动式操作平台验收表.docx VIP
- 2025版大中型企业安全生产标准化管理体系全套管理手册和管理制度.pdf VIP
- 语文阅读教学中多元评价的探索教学研究课题报告.docx
- 兴业银行校园招聘考试笔试内容科目考试真题.docx VIP
- 2026届湖南长沙市师大附中教育集团中考物理对点突破模拟试卷含解析.doc VIP
- 第一季度专题党课:深学笃行党的二十届四中全会精神 以法治担当护航长治久安和高质量发展.docx VIP
原创力文档

文档评论(0)