【数据结构】N皇后(递归经典算法)

本文探讨了经典的N皇后问题,如何在N*N棋盘上放置皇后,使得它们互不攻击。解题思路涉及使用二维数组和方向数组来判断放置可能性,并通过递归实现回溯算法。程序实现及结果展示辅助理解这一算法。
摘要由CSDN通过智能技术生成

一、N皇后

1、题目
将n个皇后摆放在N*N的棋盘中,互相不可攻击,有多少种摆放方式,每种摆放方式具体是怎样的?

2、解题思路
解题思路:
1、将棋盘放在一个二维数组中,同时设置方向数组:
static const int dx[] = {-1,1,0,0,-1,-1,1,1,};
static const int dy[] = {-1,0,-1,1,-1,1,-1,1};
分别按照方向数组的8个方向分别延伸N个问题,只要不超过边界,mark[][] = 1;其余为0;
2、对于N*N的棋盘,每行都要放置1个且只能放置1个皇后,利用递归对棋盘的每一行放置皇后,放置时,按列顺序寻找可以放置皇后的列,若可以放置皇后,将皇后放置该位置,并更新mark标记数组,递归进行下一行皇后放置,当该次递归结束后,恢复mark数组,并尝试下一个可能放皇后的列;当递归可以完成N列的N个皇后放置,则将该结果保存并返回。
3、棋盘的设置与皇后的放置

4、N皇后回溯算法

5、程序实现</

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值