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

温州网站优化页面如何迁移wordpress

温州网站优化页面,如何迁移wordpress,股票跟单网站开发,东莞关键词优化平台按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上,并且使皇后彼此之间不能相互攻击。 给你一个整数 n ,返回所有不同的 n 皇后问题 的解决方案。 每一种…

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

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

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

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

思路一:动态规划

int solutionsSize;char** generateBoard(int* queens, int n) {char** board = (char**)malloc(sizeof(char*) * n);for (int i = 0; i < n; i++) {board[i] = (char*)malloc(sizeof(char) * (n + 1));for (int j = 0; j < n; j++) board[i][j] = '.';board[i][queens[i]] = 'Q', board[i][n] = 0;}return board;
}void backtrack(char*** solutions, int* queens, int n, int row, int* columns, int* diagonals1, int* diagonals2) {if (row == n) {char** board = generateBoard(queens, n);solutions[solutionsSize++] = board;} else {for (int i = 0; i < n; i++) {if (columns[i]) {continue;}int diagonal1 = row - i + n - 1;if (diagonals1[diagonal1]) {continue;}int diagonal2 = row + i;if (diagonals2[diagonal2]) {continue;}queens[row] = i;columns[i] = true;diagonals1[diagonal1] = true;diagonals2[diagonal2] = true;backtrack(solutions, queens, n, row + 1, columns, diagonals1, diagonals2);queens[row] = -1;columns[i] = false;diagonals1[diagonal1] = false;diagonals2[diagonal2] = false;}}
}char*** solveNQueens(int n, int* returnSize, int** returnColumnSizes) {char*** solutions = malloc(sizeof(char**) * 501);solutionsSize = 0;int queens[n];int columns[n];int diagonals1[n + n];int diagonals2[n + n];memset(queens, -1, sizeof(queens));memset(columns, 0, sizeof(columns));memset(diagonals1, 0, sizeof(diagonals1));memset(diagonals2, 0, sizeof(diagonals2));backtrack(solutions, queens, n, 0, columns, diagonals1, diagonals2);*returnSize = solutionsSize;*returnColumnSizes = malloc(sizeof(int*) * solutionsSize);for (int i = 0; i < solutionsSize; i++) {(*returnColumnSizes)[i] = n;}return solutions;
}

分析:

本题为经典的n皇后问题,对题中要求皇后不能在同一行同一列或同一45度斜线上,可采用动态规划的方法,将皇后所在位置赋值为true,使皇后之间不能在同一行同一列或同一45度斜线上,再接着递归下去,找到所有可能的情况。同时在判断皇后不在同一45度斜线上时,只需判断每个皇后的左斜上是否有皇后即可,若有则该情况不成立。

总结:

本题考察动态规划和递归的应用,需判断好皇后位置的限制条件进行递归。

http://www.hyszgw.com/news/51899/

相关文章:

  • 公司微网站建设短视频营销案例分析
  • 同城网站专业网站设计师去哪找
  • 免费做网站公司哪家好宁波建网站推荐
  • 网页浏览器排行榜前十名电影网站做seo
  • 滁州市建设工程质量监督站网站本地搭建wordpress建站教程
  • 深圳专业做网站设计公司建设配资网站有要求吗
  • 酷炫的网站模板免费下载江苏省住房与城乡建设部网站
  • wordpress建站教程linux网络营销包括哪些基本内容
  • 免费建站网站一级大录像不卡在线看电子购物网站建设目的
  • 手机网站设计公司哪家好公司有些网站打不开
  • 哪家公司做网站便宜黄山旅游攻略景点必去
  • 河北平台网站建设价位网站优化设计的基础是网站基本要素及每个细节的优化
  • 商城网站服务器租用天津网站设计开发
  • 网站开发需要会什么软件专业企业网站建设
  • 全新正版营销网站wordpress翻译过时了
  • 莱芜有需要制作网站的公司吗定制网络流量监控软件
  • 大连网站建设顾问公司页面图片
  • 泰州网页网站制作网站色哦优化8888
  • 福建省住房和城乡建设厅官方网站北京百度快照推广公司
  • 美容美发网站模板建筑装饰工程
  • 厦门市同安区建设局官方网站如何架设内部网站
  • 海南 网站 建设广东东莞发布最新消息
  • 网站后台管理员职责网站建设与管理的未来规划方案
  • 百度官方网站网址是多少针对网站开发者的问答网站
  • 做刷网站流量犯法吗4366网页游戏
  • 湖南微网站营销易语言如何做浏网站
  • 注册网站授权书怎么写哪些网站用echarts做的
  • ppt制作网站推荐静态网站如何做自适应移动端
  • 汉语网站建设心得天元建设集团有限公司破产重组
  • 简洁大气的网站首页太原建站一条龙