[LeetCode] N皇后问题
LeetCode上面关于N皇后有两道题目:
51 N-Queens:https://leetcode.com/problems/n-queens/description/
52 N-Queens II:https://leetcode.com/problems/n-queens-ii/description/
两道题目其实差不多,一题是只要返回解的个数就可以了,一题是返回所有的解,做起来一模一样。
什么是N皇后问题?我们需要在一个N*N的棋盘上,放置N个皇后,使这些皇后不能互相攻击(即两个皇后之间不能处于同一行、同一列或者是同一斜线上),我们要求满足这个条件的所有解。
我采用的是回溯法去解决N皇后问题:
我们先在第一列放置一个皇后,然后在第二列与第一列不冲突的位置再放皇后,在第三列与第一列、第二列不冲突的位置放皇后……执行这样的操作,一直到第N列,我们就得到一个解了。
怎么回溯呢?我们可以想象成一棵树。假设我们在第一列的第一行放置了皇后,然后递归模拟了所有情况后,把第一列的第一行的皇后放到第二行,继续递归模拟所有情况。一直到把所有解都得出来。
下面看看LeetCode的具体题目:
51 N-Queens:
题目:

代码:
class Solution {
public:
vector<vector<string>> solveNQueens(int n) {
vector<vector<string>> res;
vector<string> queens(n);
for (int i = ; i < n; i++) {
queens[i] = "";
for (int j = ; j < n; j++) {
queens[i] += ".";
}
}
helper(res, queens, , n);
return res;
}
void helper(vector<vector<string>> &res, vector<string> queens, int j, int n) {
if (j == n) {
res.push_back(queens);
return;
}
for (int i = ; i < n; i++) {
if (isValid(queens, i, j)) {
queens[i][j] = 'Q';
helper(res, queens, j + , n);
queens[i][j] = '.';
}
}
}
bool isValid(vector<string> s, int i, int j) {
for (int k = ; k < s.size(); k++) {
if (i != k && s[k][j] == 'Q') return false;
}
for (int k = ; k < s.size(); k++) {
if (j != k && s[i][k] == 'Q') return false;
}
for (int m = i + , n = j + ; m < s.size() && n < s.size(); m++, n++) {
if (s[m][n] == 'Q') return false;
}
for (int m = i + , n = j - ; m < s.size() && n >= ; m++, n--) {
if (s[m][n] == 'Q') return false;
}
for (int m = i - , n = j - ; m >= && n >= ; m--, n--) {
if (s[m][n] == 'Q') return false;
}
for (int m = i - , n = j + ; m >= && n < s.size(); m--, n++) {
if (s[m][n] == 'Q') return false;
}
return true;
}
};
52 N-Queens II:
题目:

代码:
class Solution {
public:
int totalNQueens(int n) {
vector<string> queens(n);
for (int i = ; i < n; i++) {
queens[i] = "";
for (int j = ; j < n; j++) {
queens[i] += '';
}
}
int res = ;
helper(res, queens, , n);
return res;
}
void helper(int &res, vector<string> queens, int j, int n) {
if (j == n) {
res++;
return;
}
for (int i = ; i < n; i++) {
if (isValid(queens, i, j)) {
queens[i][j] = '';
helper(res, queens, j + , n);
queens[i][j] = '';
}
}
}
bool isValid(vector<string> queens, int i, int j) {
for (int k = ; k < queens.size(); k++) {
if (queens[i][k] == '' && k != j) return false;
}
for (int k = ; k < queens.size(); k++) {
if (queens[k][j] == '' && k != i) return false;
}
for (int m = i - , n = j - ; m >= && n >= ; m--, n--) {
if (queens[m][n] == '') return false;
}
for (int m = i + , n = j - ; m < queens.size() && n >= ; m++, n--) {
if (queens[m][n] == '') return false;
}
for (int m = i - , n = j + ; m >= && n < queens.size(); m--, n++) {
if (queens[m][n] == '') return false;
}
for (int m = i + , n = j + ; m < queens.size() && n < queens.size(); m++, n++) {
if (queens[m][n] == '') return false;
}
return true;
}
};
除了原来的函数,我们用到了一个用于回溯的helper函数,一个用于检测当前位置是否可放置皇后的函数。
[LeetCode] N皇后问题的更多相关文章
- LeetCode N皇后 & N皇后 II
题目链接:https://leetcode-cn.com/problems/n-queens/ 题目链接:https://leetcode-cn.com/problems/n-queens-ii/ 题 ...
- [LeetCode] N-Queens II N皇后问题之二
Follow up for N-Queens problem. Now, instead outputting board configurations, return the total numbe ...
- [LeetCode] N-Queens N皇后问题
The n-queens puzzle is the problem of placing n queens on an n×n chessboard such that no two queens ...
- Leetcode之回溯法专题-52. N皇后 II(N-Queens II)
Leetcode之回溯法专题-52. N皇后 II(N-Queens II) 与51题的代码80%一样,只不过52要求解的数量,51求具体解,点击进入51 class Solution { int a ...
- Leetcode之回溯法专题-51. N皇后(N-Queens)
Leetcode之回溯法专题-51. N皇后(N-Queens) n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击. 上图为 8 皇后问题的一种解法. 给 ...
- [LeetCode] 52. N-Queens II N皇后问题之二
The n-queens puzzle is the problem of placing nqueens on an n×n chessboard such that no two queens a ...
- [LeetCode] 51. N-Queens N皇后问题
The n-queens puzzle is the problem of placing n queens on an n×n chessboard such that no two queens ...
- [LeetCode] 52. N-Queens II N皇后问题 II
The n-queens puzzle is the problem of placing n queens on an n×n chessboard such that no two queens ...
- LeetCode 31:递归、回溯、八皇后、全排列一篇文章全讲清楚
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天我们讲的是LeetCode的31题,这是一道非常经典的问题,经常会在面试当中遇到.在今天的文章当中除了关于题目的分析和解答之外,我们还会 ...
随机推荐
- visual studio no editoroptiondefinition export found for the given option nam
今天用VS 2012打开项目,打开项目时,出现以下的bug.解决方法:清理了在C盘用户文件目录下的缓存. 具体的路径是:C:\Users\{当前用户}\AppData\Local\Microsoft\ ...
- vue数据请求
我是vue菜鸟,第一次用vue做项目,写一些自己的理解,可能有些不正确,欢迎纠正. vue开发环境要配置本地代理服务.把config文件加下的index.js里的dev添加一些内容, dev: { e ...
- LeetCode 152. Maximum Product Subarray (最大乘积子数组)
Find the contiguous subarray within an array (containing at least one number) which has the largest ...
- LeetCode 66. Plus One(加1)
Given a non-negative integer represented as a non-empty array of digits, plus one to the integer. Yo ...
- Spring MVC前后端的数据传输
本篇文章主要介绍了Spring MVC中如何在前后端传输数据. 后端 ➡ 前端 在Spring MVC中这主要通过Model将数据从后端传送到前端,一般的写法为: @RequestMapping(va ...
- 微信小程序获取微信的openid
通过登录接口获取登录凭证,然后通过request请求后台获取openid,需要把后台域名放到小程序后台的request 合法域名内: 1.wx.login 获取登录凭证 2.wx.request 发 ...
- gulp-prompt入个了门
gulp-prompt版本:0.4.1 源码:gulp-prompt 一.gulp-prompt的简介 gulp-prompt 是一个基于gulp的命令行提示. 我们可以用它来完成命令行中互动功能. ...
- JS框架设计读书笔记之-核心模块
随笔记录一下读书心得 1. 框架模块-核心模块 该模块是框架最先执行的部分,jQuery与vue中都有初始化的代码. 模块的功能主要是:对象扩展.数组化.类型判定.事件绑定和解绑.无冲突处理.模块加载 ...
- ubuntu上安装adt时无法在线安装的问题
安装了新的ubuntu系统之后,就得重新布置android开发环境了. 找了网上的教程,一步一步做,到了在eclipse上在线下载adt总是出现 Unable to connect to reposi ...
- HDFS的接口(命令行接口和Java接口)--笔记
HDFS 文件的系统访问的接口 1.Hadoop的shell命令脚本 hadoop fs -ls 列出某一个目录下的文件 hadoop fs -lsr 递归的方式列出所有文件 hadoop fs ...