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

网站建设与管理试题及答案bittorrentkitty磁力猫

网站建设与管理试题及答案,bittorrentkitty磁力猫,页面模板怎么添加文章,wordpress 4.61这道题之前刷代码随想录的时候跳过了,然后今天是第一次做这个题目,感觉很难,然后去看了代码随想录对应的视频才做出来的。这里主要讲一下思路。 我们首先定义一个递归函数backtracking(),输入参数分别为int row,vector…


这道题之前刷代码随想录的时候跳过了,然后今天是第一次做这个题目,感觉很难,然后去看了代码随想录对应的视频才做出来的。这里主要讲一下思路。
我们首先定义一个递归函数backtracking(),输入参数分别为int rowvector<string>& chessboardint n,其中row表示当前正在第row行填皇后,chessboard表示棋盘,n表示棋盘的尺寸为n * n。显而易见,当row >= n时,则说明0 ~ n - 1行的皇后已经全部填完,则直接收获结果。否则进入递归主体逻辑。由于我们是讨论第row行的皇后放置问题,0 ~ row - 1行已经填好了,而第row行及以后的行则尚未放置,所以我们需要分别讨论在第row行的每一列上放置皇后的结果,我们还需要额外定义一个辅助函数is_valid()来判断在第row行第col列放置皇后是否合法,具体来说,我们通过检查同列,斜上45°和斜上135°(因为第row行及以后的行尚未放置皇后,不可能发生冲突,只需要向上检查即可)是否存在冲突,只要上述三种情况下都没有发现皇后,则说明当前位置可以放置皇后,将当前位置赋值为'Q',并进入下一行的递归:backtracking(row + 1, chessboard, n);当递归调用返回后,需及时回溯,将之前的合法位置处的皇后及时赋值为空地。若不及时回溯,则随着循环的进行,每一行都会塞满皇后。

class Solution {
public:vector<vector<string>> result;   //记录所有符合条件的结果bool is_valid(int row, int col, vector<string>& chessboard, int n){//想在chessboard[row][col]处放置皇后(还没放),判断该位置是否合法,棋盘大小为n * n//观察同一列中有没有放置皇后for(int i = 0; i < n; 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) {vector<string> chessboard(n, string(n, '.'));  //初始化棋盘backtracking(0, chessboard, n);   return result;}//递归函数void backtracking(int row, vector<string>& chessboard, int n){//递归终止条件if(row >= n){  //0 ~ n - 1行全部放置完毕result.emplace_back(chessboard);return ;}for(int col = 0; col < n; col++){   //在当前行遍历所有的列,寻找放置位置if(is_valid(row, col, chessboard, n)){chessboard[row][col] = 'Q';   //在合法位置放置皇后backtracking(row + 1, chessboard, n);  chessboard[row][col] = '.';  //回溯}}}
};
http://www.dtcms.com/wzjs/101505.html

相关文章:

  • 哪个网站可以免费建站啊免费建网站app推广一手单
  • 模板网站代理西安网站托管
  • 合肥品牌网站建设厦门seo俱乐部
  • 中国建设银行官网站和字币预约企业网站的网络营销功能
  • 网站租用一年服务器费用多少seo薪酬
  • 欧美网站建设考研比较厉害的培训机构
  • 杭州网站推广排名自己的网站怎么建立
  • php做彩票网站免费站推广网站不用下载
  • 政务网站的建设原则百度人工客服在线咨询电话
  • 做网站 信科网站建设便宜seo关键词优化软件手机
  • 做网站需要自己研发吗十大洗脑广告
  • 企业网站的形式自己如何建立网站
  • 3d标签 wordpress肇庆网站快速排名优化
  • asp网站后台管理系统下载关键词优化推广公司
  • 长春市委网站群排名优化软件
  • seo网站做推广的公司百度搜索高级搜索技巧
  • 网站建设与维护题库及答案在线生成网站
  • 手机建站平台微点培训班学员培训心得
  • 学校网站建设及使用宁波seo深度优化平台
  • 网站基建建设网络舆情管理
  • 南阳卧龙区网站建设哪家好网站建设培训
  • 中交路桥建设有限公司是国企吗seo教学培训
  • 微信 网站提成方案点做手机版百度入口
  • 网站的布局分类在哪里可以发布自己的广告
  • 做的好微信商城网站360营销推广
  • 一般做网站的在哪里找今日新闻国际头条新闻
  • 做网站简介二级域名网站查询入口
  • 刚做的网站怎么快速搜索到拉新app推广平台
  • 网站内搜索关键字商旅100网页版
  • 网站标志的原则杭州seo搜索引擎优化