当前位置: 首页 > news >正文

东南亚做网站 什么语言正规拉新推广平台有哪些

东南亚做网站 什么语言,正规拉新推广平台有哪些,公司网站建设推广,朗姿青春日记 网站谁做的Leetcode 51. N皇后 题目链接:51 N皇后 题干:按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上,并且使皇后彼此之间不能相互攻击。 给你一个整…

Leetcode 51. N皇后

题目链接:51 N皇后

题干:按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。

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

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

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

思考:回溯法。先定义结果集result,再考虑回溯函数:

函数参数含义
参数含义
n题目给定皇后个数
chessboard当前棋盘摆放情况
row当前处理行数

 终止条件:如果当前处理行数row等于n时说明皇后已全部摆放完毕,将当前棋盘摆放情况chessboard存放到结果集result中。

单层搜索逻辑:从下标0开始循环处理每个二维坐标位置,若当前行row当前列col存放皇后合法则摆放皇后,递归处理,最后回溯。

验证row行col列摆放皇后合法性:参数当前行列值,当前棋盘以及皇后个数。三处标准判断合法性:不能同行(每次处理都是不同行故此标准不用验证)、不能同列、不能同斜线 (45度和135度角)。

  • 判断同列:当前row行前面的所以行对应的col列是否摆放过皇后
  • 判断45°线:当前row行col列45°斜方向是否摆放过皇后
  • 判断135°线:当前row行col列135°斜方向是否摆放过皇后

代码:

class Solution {
public:vector<vector<string>> result;//n : 皇后个数  chessboard : 当前棋盘摆放情况   row : 当前处理行数void backtracking(const int n, vector<string>& chessboard, int row) {if (row == n) {result.push_back(chessboard);return;}for (int col = 0; col < n; col++) {if (isValid(n, chessboard, row, col)) {chessboard[row][col] = 'Q';     //摆放皇后backtracking(n, chessboard, row + 1);chessboard[row][col] = '.';     //回溯}}}//判断row行col列摆放皇后是否合法bool isValid(const int n, vector<string>& chessboard, int row, int col) {//检查此行是否摆放过皇后for (int i = 0; i < row; i++)       if (chessboard[i][col] == 'Q')return false;//检查45°线是否摆放过皇后for (int i = row - 1, j = col - 1; i >= 0 && j >= 0; i--, j--)      if (chessboard[i][j] == 'Q')return false;//检查135°线是否摆放过皇后for (int i = row - 1, j = col + 1; i >= 0 && j < n; i--, j++)if (chessboard[i][j] == 'Q')return false;return true;}vector<vector<string>> solveNQueens(int n) {result.clear();vector<string> chessboard(n, string(n, '.'));backtracking(n, chessboard, 0);return result;}
};

回溯法专题总结:

  •  熟悉回溯法代码整体框架。把回溯问题抽象为树形结构,其搜索的过程:for循环横向遍历,递归纵向遍历,回溯不断调整结果集。
  • 确定是否使用startIndex。对于组合问题,如果是一个集合来求组合的话,就需要startIndex;如果是多个集合取组合,各个集合之间相互不影响,那么就不用startIndex。
  • 熟悉同层去重两种方式。排序后相邻元素比较以及set容器记录使用情况。了解到节点去重,但未归纳。
  • 明确在树形结构中子集问题是要收集所有节点的结果,而组合问题是收集叶子节点的结果。
http://www.ds6.com.cn/news/62191.html

相关文章:

  • 网站竞价如何做百度网盘电脑版
  • 301的网站用什么来做seo培训课程
  • 济南 网站建设今日新闻头条热点
  • 做网站自己买服务器吗网络推广运营途径
  • wordpress如何嵌入b站视频优秀软文范例
  • 快照网站市场营销平台
  • 网页版传奇游戏排行榜信息流广告优化师
  • 做网站合伙怎么分网站收录是什么意思
  • 校园类网站模板免费下载公司推广渠道有哪些
  • 进出口贸易网站制作东莞网站推广优化网站
  • 正规的网站建设企业网站制作网络营销公司怎么注册
  • wordpress弹窗视频seo网站排名的软件
  • 北京个人做网站b2b网站大全免费推广
  • 网站背景设计公司的seo是什么意思
  • 佛山企业门户网站建设软文写作经验
  • wordpress批量urlwin10优化大师怎么样
  • 创新的网站建站小黄豆crm
  • 在线查看网站源码企业门户网站模板
  • 个人软件制作网站网络软文发布平台
  • 换接入商网站备案新闻稿发布
  • 棠下网站建设免费加精准客源
  • 长沙旅游攻略三日游seo专业技术培训
  • 专业创建网站正规seo关键词排名网络公司
  • pc软件下载网站网站推广技巧有哪些
  • wordpress投稿vipseo优化官网
  • 网站排名优化金苹果下拉提高百度搜索排名
  • 正规品牌网站设计品牌seo营销推广服务公司
  • 网站帮企业做推广价格怎么算百度竞价排名公式
  • 大连网站的优化电商数据查询平台
  • 石家庄 科技 公司 网站建设seo网站关键词优化