力扣--N皇后

题目:

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

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

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

cpp 复制代码
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/

相关推荐
唐僧洗头爱飘柔95273 分钟前
【SpringCloud(8)】SpringCloud Stream消息驱动;Stream思想;生产者、消费者搭建
后端·spring·spring cloud·设计思想·stream消息驱动·重复消费问题
韩立学长6 分钟前
【开题答辩实录分享】以《自动售货机刷脸支付系统的设计与实现》为例进行答辩实录分享
vue.js·spring boot·后端
fantasy5_58 分钟前
手撕vector:从零实现一个C++动态数组
java·开发语言·c++
GISer_Jing10 分钟前
小米前端面试
前端·面试·职场和发展
兜兜风d'19 分钟前
RabbitMQ死信队列详解
c++·rabbitmq·java-rabbitmq
丁浩66626 分钟前
统计学---2.描述性统计-参数估计
人工智能·算法
C_Liu_30 分钟前
12.C++:模版进阶
开发语言·c++
月明泉清35 分钟前
最近的面试,被打击了(随笔)
职场和发展·跳槽
cj6341181501 小时前
DBeaver连接本地MySQL、创建数据库表的基础操作
java·后端