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皇后问题的更多相关文章

  1. LeetCode N皇后 & N皇后 II

    题目链接:https://leetcode-cn.com/problems/n-queens/ 题目链接:https://leetcode-cn.com/problems/n-queens-ii/ 题 ...

  2. [LeetCode] N-Queens II N皇后问题之二

    Follow up for N-Queens problem. Now, instead outputting board configurations, return the total numbe ...

  3. [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 ...

  4. Leetcode之回溯法专题-52. N皇后 II(N-Queens II)

    Leetcode之回溯法专题-52. N皇后 II(N-Queens II) 与51题的代码80%一样,只不过52要求解的数量,51求具体解,点击进入51 class Solution { int a ...

  5. Leetcode之回溯法专题-51. N皇后(N-Queens)

    Leetcode之回溯法专题-51. N皇后(N-Queens) n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击. 上图为 8 皇后问题的一种解法. 给 ...

  6. [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 ...

  7. [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 ...

  8. [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 ...

  9. LeetCode 31:递归、回溯、八皇后、全排列一篇文章全讲清楚

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天我们讲的是LeetCode的31题,这是一道非常经典的问题,经常会在面试当中遇到.在今天的文章当中除了关于题目的分析和解答之外,我们还会 ...

随机推荐

  1. TsBatis 预览

    前言 在发布了 mybatis-dynamic-query之后感觉基本功能稳定了,而且现在在工作项目开发效率大大提高,而且非常易于维护. 最近准备带几个小朋友以前用typescript 打通前后端,当 ...

  2. 使用VS2013 + EF6 + .NET4.5 连接Mysql数据库

    1.安装插件 在使用Visual Studio 2013添加ADO.NET实体数据模型新建连接时,默认是没有Mysql选项的.此时我们需要安装两个东西: 1.mysql-for-visualstudi ...

  3. ansible服务部署与使用

    第1章 ssh+key实现基于密钥连接(ansible使用前提) 说明:    ansible其功能实现基于SSH远程连接服务    使用ansible需要首先实现ssh密钥连接 1.1 部署ssh ...

  4. centos7 最小安装无ifconfig

    可能不会有人看到这篇文章,加入有幸被看到,建议读者从后往前看!最小化安装问题:1   没有ifconfig 命令,解决:yum install net-tools2   使用yum install n ...

  5. 写了一个bug,最后却变成了feature,要不要修呢?

    事情是这样子的,前不久接到一个需求,为一个游戏开发礼包码功能 通常一款游戏运营期间会搞各种各样的活动吸引玩家,其中最常见的就是发放礼包,  玩家可以通过礼包码兑换礼包. 用礼包码兑换礼包有个一限制,游 ...

  6. JSON.stringify实战用法

    1.首先定义一个数组 var teamPlanMinList = new Array(); 2. 定义一个json对象 var json = { "plname":plname, ...

  7. Leetcode题解(一)

    1.Two Sum 题目 此题第一解题思路,就是最常见的方法,两个指针嵌套遍历数组,依次判断当前指针所指向的值是否满足条件.代码如下; class Solution { public: vector& ...

  8. html网页中加载js脚本 下载下来是乱码(文件编码格式)

    问题描述: 在一个index.html网页中,引入了jquery脚本,但是却出现错误,提示$ is not defined <!DOCTYPE html> <html lang=&q ...

  9. 原生js实现简单移动端轮播图

    最近项目不是很忙,自己就用原生js写了一个简单的移动端轮播图的小demo,可实现自动轮播和手势滑动轮播,然后就把它记录到个人博客里.还有很多不足的地方,希望多多指出,以便改进. 1.代码部分 分为四个 ...

  10. (原创)遗传算法C++实现

    本文没有对遗传算法的原理做过多的解释 基础知识可以参考下面的博客:http://blog.csdn.net/u010451580/article/details/51178225 本实验用到的变异用到 ...