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

如何创作个人网站手机免费发布信息平台

如何创作个人网站,手机免费发布信息平台,三水区网站建设,淮南最新消息今天发布题目链接 /** 将n个棋子放在n*n的棋盘上,不同列,不同行,不同斜线 大致执行流程: 首先选取第一行第一格放置第一个棋子,再从第二行第一个位置开始选取合法的位置(不同行不同列不同斜线)放置棋子,重复上述流程迭代行数, 直到放置n个棋子。 若放置途中出现无合法位置的情况,回溯将…

题目链接

/**

            将n个棋子放在n*n的棋盘上,不同列,不同行,不同斜线

            大致执行流程:

                    首先选取第一行第一格放置第一个棋子,再从第二行第一个位置开始选取合法的位置(不同行不同列不同斜线)放置棋子,重复上述流程迭代行数,

                    直到放置n个棋子。

                    若放置途中出现无合法位置的情况,回溯将上一行棋子放置在其他合法位置,再重复上述流程继续放置直到n个棋子。

                    成功放置n个棋子后得到第一种情况,开始回溯重复上述流程,直到回溯至第一行的每个格子都尝试过,得到所有结果

            额外方法:

                    boolean isValid 检查欲放置位置的合法性

                    List<String> BoardToList 棋盘格式转换

 */

class Solution {//棋盘private char[][] board;//保存结果private List<List<String>> res = new ArrayList<>();//避免重复传参private int n;public List<List<String>> solveNQueens(int n) {/**将n个棋子放在n*n的棋盘上,不同列,不同行,不同斜线大致执行流程:首先选取第一行第一格放置第一个棋子,再从第二行第一个位置开始选取合法的位置(不同行不同列不同斜线)放置棋子,重复上述流程迭代行数,直到放置n个棋子。若放置途中出现无合法位置的情况,回溯将上一行棋子放置在其他合法位置,再重复上述流程继续放置直到n个棋子。成功放置n个棋子后得到第一种情况,开始回溯重复上述流程,直到回溯至第一行的每个格子都尝试过,得到所有结果额外方法:boolean isValid 检查欲放置位置的合法性List<String> BoardToList 棋盘格式转换*/this.n = n;this.board = new char[n][n];//初始化棋盘for(int i = 0; i < n; i++) {for(int j = 0; j < n; j++) {board[i][j] = '.';}}//开始放置backtrack(0);return res;}private void backtrack(int row) {//已放置n个棋子,保存结果if(row == n) {res.add(BoardToList());return;}for(int col = 0; col < n; col++) {//当前位置合法if(isValid(row,col)) {board[row][col] = 'Q';backtrack(row + 1);//回溯board[row][col] = '.';}}}//判断合法性 判断不同列不同斜线即可,同行已由index控制private boolean isValid(int row, int col) {//检查列冲突 row可体现出已放置棋子数 i < row 避免不必要的检查for(int i = 0; i < row; i++) {if(board[i][col] == 'Q') {return false;}}//左下对角(上方无棋子,无需检查左上)for (int i = row - 1, j = col - 1; i >= 0 && j >= 0; i--, j--) {if (board[i][j] == 'Q') {return false;}}//右下对角(上方无棋子,无需检查右上)for (int i = row - 1, j = col + 1; i >= 0 && j < n; i--, j++) {if (board[i][j] == 'Q') {return false;}}return true;}// 将棋盘转换为结果格式(List<String>)private List<String> BoardToList() {List<String> list = new ArrayList<>();for (int i = 0; i < n; i++) {list.add(new String(board[i])); //按行批量转化}return list;}}

http://www.dtcms.com/wzjs/369228.html

相关文章:

  • 聊城网站设计爱论坛
  • 网站建站中关键字搜索怎么弄关键词排名方法
  • 淄博网站推广哪家好东莞网站建设做网站
  • 网站建设费一般是什么费用衡水seo优化
  • 做下载网站有哪些提交网址给百度
  • 网站限制浏览次数是怎么做的免费查权重工具
  • 做机械有什么兼职网站合肥网站推广
  • flash企业网站搜索app下载
  • 建站工具官网2021网络营销成功案例
  • dede网站地图 调用文章seo网址超级外链工具
  • 广西住房与城乡建设厅网站百度推广首页
  • 昆山网站制作nba最新排行榜
  • 网盘做网站空间友情链接交换源码
  • 北京城乡建设门户网站新手电商运营从哪开始学
  • 小说网站系统怎么做浙江网络科技有限公司
  • 如何查看网站的外链站长基地
  • wap网站做微信小程序百度一下首页网址
  • 如何建立国际网站什么公司适合做seo优化
  • 建设部人事教育司网站镇海seo关键词优化费用
  • 怎么在子域名建立一个不同的网站seo网站关键词优化快速官网
  • 企业内部的网站系统win10优化工具下载
  • 佛山市多语言营销型网站建站tool站长工具
  • 做自媒体有哪些素材网站郑州百度搜索优化
  • 商城网站建站系统nba最新新闻消息
  • 网站首页图片滑动怎么做自助建站系统代理
  • 苏州市建设交易中心网站平台接广告在哪里接的
  • 济南做外贸网站的公司列举常见的网络营销工具
  • 网站定制建设哪里好百度风云排行榜官网
  • 美食网站界面设计白杨seo
  • 专门做别墅的网站跨国网站浏览器