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

相关推荐
bobz9652 小时前
小语言模型是真正的未来
后端
Coovally AI模型快速验证2 小时前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·yolo·计算机视觉·transformer·无人机
mit6.8242 小时前
[openvela] Hello World :从零开始的完整实践与问题复盘
c++·嵌入式硬件
pusue_the_sun2 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
DevYK2 小时前
企业级 Agent 开发实战(一) LangGraph 快速入门
后端·llm·agent
RaymondZhao343 小时前
【全面推导】策略梯度算法:公式、偏差方差与进化
人工智能·深度学习·算法·机器学习·chatgpt
zhangfeng11333 小时前
DBSCAN算法详解和参数优化,基于密度的空间聚类算法,特别擅长处理不规则形状的聚类和噪声数据
算法·机器学习·聚类
一只叫煤球的猫3 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试
冒泡的肥皂3 小时前
MVCC初学demo(一
数据库·后端·mysql
圣保罗的大教堂3 小时前
leetcode 2348. 全 0 子数组的数目 中等
leetcode