力扣--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/

相关推荐
Larry_Yanan1 小时前
QML学习笔记(三十四)QML的GroupBox、RadioButton
c++·笔记·qt·学习·ui
程序员小凯1 小时前
Spring Boot缓存机制详解
spring boot·后端·缓存
程序员老舅1 小时前
干货|腾讯 Linux C/C++ 后端开发岗面试
linux·c语言·c++·编程·大厂面试题
乐迪信息1 小时前
乐迪信息:基于AI算法的煤矿作业人员安全规范智能监测与预警系统
大数据·人工智能·算法·安全·视觉检测·推荐算法
程序员Aries1 小时前
自定义网络协议与序列化/反序列化
linux·网络·c++·网络协议·程序人生
i学长的猫1 小时前
Ruby on Rails 从0 开始入门到进阶到高级 - 10分钟速通版
后端·ruby on rails·ruby
Pafey2 小时前
MFC中一个类的成员变量值自动被篡改:多重继承带来的问题
c++·mfc
用户21411832636022 小时前
别再为 Claude 付费!Codex + 免费模型 + cc-switch,多场景 AI 编程全搞定
后端
hsjkdhs2 小时前
C++之多层继承、多源继承、菱形继承
开发语言·c++·算法
茯苓gao2 小时前
Django网站开发记录(一)配置Mniconda,Python虚拟环境,配置Django
后端·python·django