51. N皇后

问题描述

n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。

上图为 8 皇后问题的一种解法。

给定一个整数 n,返回所有不同的 n 皇后问题的解决方案。

每一种解法包含一个明确的 n 皇后问题的棋子放置方案,该方案中 'Q' 和 '.' 分别代表了皇后和空位。

示例:

输入: 4
输出: [
[".Q..", // 解法 1
"...Q",
"Q...",
"..Q."], ["..Q.", // 解法 2
"Q...",
"...Q",
".Q.."]
]
解释: 4 皇后问题存在两个不同的解法。

问题分析

当在棋盘上放置了一个皇后后,立即排除当前行,列和对应的两个对角线。即:

代码

class Solution {
public:
vector<vector<string>> solveNQueens(int n) {
vector<string> path(n,string(n,'.'));
vector<vector<string>> ans;
backtrack(n,0,ans,path);
return ans;
}
void backtrack(int n,int row,vector<vector<string>> &ans,vector<string> &path)
{
if(row == n)
{
ans.push_back(path);
return;
}
for(int i = 0; i < n; ++i)
{
if(checkvaild(n,row,i,ans,path))
{
path[row][i] = 'Q';
backtrack(n,row+1,ans,path);
path[row][i] = '.';
}
}
}
bool checkvaild(int n,int row,int col,vector<vector<string>> &ans,vector<string> &path)
{
int i,j;
for(i = 0; i < row; i++)
{
if(path[i][col] == 'Q')return false;
}
for(i = row - 1,j = col - 1;i>=0&&j>=0;--i,--j)
{
if(path[i][j] == 'Q')return false;
}
for(i = row - 1,j = col + 1;i>=0&&j<n;--i,++j)
{
if(path[i][j] == 'Q')return false;
}
return true;
}
};

结果:

执行用时 :12 ms, 在所有 C++ 提交中击败了62.59%的用户
内存消耗 :9.5 MB, 在所有 C++ 提交中击败了100.00%的用户

52.N皇后 II

问题描述

n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。

上图为 8 皇后问题的一种解法。

给定一个整数 n,返回 n 皇后不同的解决方案的数量。

示例:

输入: 4
输出: 2
解释: 4 皇后问题存在如下两个不同的解法。
[
 [".Q..",  // 解法 1
  "...Q",
  "Q...",
  "..Q."],  ["..Q.",  // 解法 2
  "Q...",
  "...Q",
  ".Q.."]
]

代码

class Solution {
public:
int totalNQueens(int n) {
vector<string> path(n,string(n,'.'));
int num = 0;
backtrack(n,0,path,num);
return num;
}
void backtrack(int n,int row,vector<string> &path,int& num)
{
if(row == n)
{
++num;
return;
}
for(int i = 0; i < n; ++i)
{
if(checkvaild(n,row,i,path))
{
path[row][i] = 'Q';
backtrack(n,row+1,path,num);
path[row][i] = '.';
}
}
}
bool checkvaild(int n,int row,int col,vector<string> &path)
{
int i,j;
for(i = 0; i < row; i++)
{
if(path[i][col] == 'Q')return false;
}
for(i = row - 1,j = col - 1;i>=0&&j>=0;--i,--j)
{
if(path[i][j] == 'Q')return false;
}
for(i = row - 1,j = col + 1;i>=0&&j<n;--i,++j)
{
if(path[i][j] == 'Q')return false;
}
return true;
}
};

结果:

执行用时 :4 ms, 在所有 C++ 提交中击败了89.95%的用户
内存消耗 :8.5 MB, 在所有 C++ 提交中击败了30.71%的用户

参考链接

最新文章

  1. JDK历史版本
  2. 【原创】js实现一个可随意拖拽排序的菜单导航栏
  3. java HashMap那点事
  4. IIS7.5中神秘的ApplicationPoolIdentity
  5. 解决Eclipse建Maven项目module无法转换为2.3
  6. nginx yii2环境配置
  7. java笔记--超级类Object多线程的应用+哲学家进餐算法内部类与多线程结合
  8. 配置spring的事务管理
  9. android滑动基础篇 TouchView
  10. java 请求响应乱码
  11. oracle语句总结(一)
  12. 分布式CAP原理
  13. Learning part-based templates from large collections of 3D shapse CorrsTmplt Kim 代码调试
  14. 微服务架构 - 解决Docker-Compose服务编排启动顺序问题
  15. Window快捷键
  16. Confluence 6 配置一个 Confluence 环境
  17. jQuery-2.DOM---节点的复制与替换
  18. 从NetCore报错到MySql安全
  19. jquery的几种ajax方式对比
  20. Bzoj2149拆迁队:cdq分治 凸包

热门文章

  1. Office365与Office2016差异汇总
  2. LuoguB2078 含 k 个 3 的数 题解
  3. LuoguP7222 [RC-04] 信息学竞赛 题解
  4. IIS部署,发布网站
  5. layDate设置开始日期选择框和结束日期选择框 之间的相互验证方法
  6. 【LeetCode】36. Valid Sudoku 解题报告(Python)
  7. C. Andryusha and Colored Balloons
  8. Codeforces 849A:Odds and Ends(思维)
  9. 【MySQL作业】sum、max 和 min 聚合函数——美和易思聚合函数应用习题
  10. Java面向对象笔记 • 【第3章 继承与多态】