力扣--N皇后

本文介绍了如何通过编程解决经典的N皇后问题,利用回溯算法寻找在n×n棋盘上放置n个皇后,使得皇后间不互相攻击的所有可能布局。代码展示了如何用C++实现皇后放置和攻击范围的判断。
摘要由CSDN通过智能技术生成

题目:

按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。

n 皇后问题 研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。

给你一个整数 n ,返回所有不同的 n 皇后问题 的解决方案。

每一种解法包含一个不同的 n 皇后问题 的棋子放置方案,该方案中 'Q' 和 '.' 分别代表了皇后和空位。

示例 1:

输入:n = 4
输出:[[".Q..","...Q","Q...","..Q."],["..Q.","Q...","...Q",".Q.."]]
解释:如上图所示,4 皇后问题存在两个不同的解法。

示例 2:

输入:n = 1
输出:[["Q"]]

提示:

  • 1 <= n <= 9

该问题为典型的回溯问题,来看看代码吧

class Solution {
public:
void put_queen(int x,int y,vector<vector<int>>&attack)//x,y分别表示传进去的行和列,attack数组表示该行皇后可以攻击到的位置
{
	static const int dx[]={-1,1,0,0,-1,-1,1,1};
	static const int dy[]={0,0,-1,1,-1,1,-1,1};
	attack[x][y]=1;
	for(unsigned int i=1;i<attack.size();i++){
		for(int j=0;j<8;j++){
			unsigned int nx=x+i*dx[j];
			unsigned int ny=y+i*dy[j];
			if(nx>=0&&nx<attack.size()&&ny>=0&&ny<attack.size()){
				attack[nx][ny]=1;
			}
		}
	}
}
//line表示当前处理的行,n表示N皇后问题,queen数组表示皇后存储的位置,attack表示皇后攻击的位置,re表示存储N皇后的全部解法
void backtrack(int line,int n,vector<string>&queen,vector<vector<int>>&attack,vector<vector<string>>&re)
{
	if(line==n){
		re.push_back(queen);
		return;
	}
	for(int i=0;i<n;i++){
		if(attack[line][i]==0){
			vector<vector<int>> temp=attack;
			queen[line][i]='Q';
			put_queen(line,i,attack);
			backtrack(line+1,n,queen,attack,re);
			attack=temp;
			queen[line][i]='.';
		}
	}
}
    vector<vector<string>> solveNQueens(int n) {
        vector<vector<string>> re;//存储最终结果
	vector<vector<int>> attack;//标记皇后攻击位置
	vector<string>queen;//保存皇后位置
	for(int i=0;i<n;i++){
		attack.push_back((std::vector<int>()));
		for(int j=0;j<n;j++)attack[i].push_back(0);
		queen.push_back("");
        queen[i].append(n,'.');
	}
	backtrack(0,n,queen,attack,re);
	return re;
    }
};

这里我把题目链接贴上供各位查看

https://leetcode.cn/problems/n-queens/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

银氨溶液

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值