NQueens, NQueens2 N皇后问题,递归回溯

N皇后的规则:任意两个皇后不在同一行,不在同一列,不在同一斜线上。

算法分析:这种问题就用回溯法。深度搜索然后回溯。用一个数组记录每一行皇后的位置,下标代表行,值代表列。对行深度搜索。

public class NQueens 
{public List<List<String>> solveNQueens(int n){List<List<String>> res = new ArrayList<>();if(n <= 0){return res;}int[] columnVal = new int[n];DFS_helper(n, res, 0, columnVal);return res;}public void DFS_helper(int queensNum, List<List<String>> res, int row, int[] columnVal){if(row == queensNum)//已经遍历所有行了,得到结果{List<String> list = new ArrayList<>();for(int i = 0; i < queensNum; i ++){StringBuffer sb = new StringBuffer();for(int j = 0; j < queensNum; j ++){if(j == columnVal[i]){sb.append("Q");}else{sb.append(".");}}list.add(sb.toString());}res.add(list);}else{for(int i = 0; i < queensNum; i ++){columnVal[row] = i;if(isValid(row, columnVal))//合法,就寻找下一行的位置,否则,变换当前行的值{DFS_helper(queensNum, res, row+1, columnVal);}}}}public boolean isValid(int row, int[] columnVal){for(int i = 0; i < row; i ++){if(columnVal[i] == columnVal[row] || Math.abs(columnVal[row] - columnVal[i])== row - i){return false;}}return true;}public static void main(String[] args){NQueens q = new NQueens();List<List<String>> list = q.solveNQueens(8);Iterator<List<String>> it = list.iterator();int count = 0;while(it.hasNext()){System.out.println(it.next());count ++;}System.out.println(count);}
}

NQueens2:计算有多少种解决方案。

算法分析:用一个成员变量来记录解决方案的个数。

public class Nqueens2 {public int count;public int totalNQueens(int n){count = 0;if(n <= 0){return count;}int[] columnVal = new int[n];DFS_helper(n, 0, columnVal);return count;}public void DFS_helper(int queensNum, int row, int[] columnVal){if(row == queensNum)//已经遍历所有行了,得到结果{count ++;}else{for(int i = 0; i < queensNum; i ++){columnVal[row] = i;if(isValid(row, columnVal))//合法,就寻找下一行的位置,否则,变换当前行的值{DFS_helper(queensNum, row+1, columnVal);}}}}public boolean isValid(int row, int[] columnVal){for(int i = 0; i < row; i ++){if(columnVal[i] == columnVal[row] || Math.abs(columnVal[row] - columnVal[i])== row - i){return false;}}return true;}
}

 

转载于:https://www.cnblogs.com/masterlibin/p/5760847.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/403306.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mac OS 如何更改文件的默认打开方式

From: http://www.ipc.me/os-x-xiao-ji-qiao.html 和使用 Windows PC 一样&#xff0c;人们在 Mac 电脑中往往也需要用多种应用开启同一种文件。并且&#xff0c;由于环境、习惯以及个人喜好不同&#xff0c;用户常常会希望更改某种文件的默认打开方式…… 在 OS X 系统下&a…

VMware “Transport(VMDB)error -44:Message”

这种情况说明虚拟机的一个服务没有开启&#xff0c;在本机中找到服务&#xff1a; 1. “打开运行”-“services.msc”回车。 2. 找到VMware Authorization Service这个服务&#xff0c;启动起来就OK了。

linux-shell面试题 之二

标签&#xff1a;面试题 shell 正则表达式 开发 sed 原创作品&#xff0c;允许转载&#xff0c;转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://president.blog.51cto.com/4990508/854249由于工作的关系&#xff0c;收集了很多的s…

python基础学习1-列表使用

python 列表相关操作方法namelist [a,b,c,d,1,2,3,4]namelist1 [a,b,c,d,1,2,3,4]print(namelist)print(namelist[1])#取得第2个print(namelist[-1])#取得最后一个 索引从最后开始 -1,-2,-3print(namelist[0:3]) #取得列表范围 0到2 3个值 不包含 3序列上的值print(namelis…

mac下卸载jdk1.7

From: http://blog.sina.com.cn/s/blog_6940cab30102vbtp.html 目前mac上有一些软件还不支持jdk1.7,只能卸载1.7,恢复到1.6,下面二个链接是官网给出的卸载方法: http://www.java.com/zh_CN/download/help/mac_uninstall_java.xml http://docs.oracle.com/javase/7/docs/webnot…

VMware 提示”此虚拟机被配置为64位操作系统,然而,64位操作无法进行”

这种情况说明CPU没有开启虚拟化&#xff0c;需要进入主板BIOS界面进行设置&#xff0c;设置选项位置因主板而异&#xff0c;可能在 Security/Advanced/Configuration 选项下&#xff0c;以 Intel 为例&#xff0c;找到 Intel Virtual Technology / Intel HT Technology 选项&am…

el-table列宽自适应;el-table表格的列根据内容自动撑满;el-table内容换行问题;

原文链接 重点就一个方法 :width"flexColumnWidth(‘date’,tableData)" 第一个参数是这个列的字段 第二个参数是这个表格的数据 只需要给对应的列 el-table-column 标签加上此方法 即可做到此列自适应 其他的列想要自适应宽度 同样使用 :width 方法即可 此段代码可…

Android初级教程:Android中解析方式之pull解析

在安卓中有很多种解析方式。按照大方向有xml解析和json解析。而&#xff0c;细致的分&#xff0c;xml和json解析各有自己的很多解析方式。今天这一篇主要介绍xml解析中的pull解析。对于xml的解析方式&#xff0c;我之前在javaweb一些知识中有写过dom和dom4j等等解析方式。有兴趣…

linux系统下PHP无法调用oracle数据库的解决方法

我们有项目php调用oracle 在正线上环境不能运行成功。经调试通过使用如下方式&#xff1a; $param 00000999;$en cn;passthru("/usr/local/php/bin/php /home/wwwroot/pernodricard/api/test.php $param $en"); 以脚本形式可以运行成功。 怀疑是环境变量的问题&…

vi 多窗口同步滚动--适用于人工文件比较

vi本身带有文件比较功能&#xff0c;这个就不多说了&#xff0c;有时我们需要同时查看两个非常类似的文件&#xff0c;但是却有少许区别的地方&#xff0c;当然用专业的文件比较工具自然是非常方便的。 这里我只想提一下&#xff0c;vi实现多窗口同步滚动的方法, 先用vi打开两个…

安装VMware导致系统USB设备无法识别

这种情况是由于VMware的USB相关服务与系统自带USB服务冲突导致&#xff0c;因此需要禁用VMware服务并且取消开机自启动。 打开运行(命令行) –> “service.msc”回车&#xff1b;找到服务为&#xff1a;vmware usb arbitration services 与 vmware hostd。&#xff08;不同…

sqlserver 把SELECT结果集中一列的所有的值 用逗号隔开放进一个字段内

首先我们有一个表 查询结果如下: 现在我们想要把USER_NAME这一列的内容 放到一个字段里面去: 一行sql语句解决问题: SELECT STUFF(( SELECT , convert(VARCHAR, USER_NAME) FROM TE_USER FOR XML PATH()), 1, 1, ) AS UserName解释一下上面这条语句: 1,首先STUFF函数在上面的…

java-多线程-一道阿里面试题分析

2019独角兽企业重金招聘Python工程师标准>>> 传说这是阿里的一道面试题&#xff1a; 也传说发这道题出来的作者去了tmail。下面是关于题目的描述: 这段代码大多数情况下运行正常&#xff0c;但是某些情况下会出问题。什么时候会出现什么问题&#xff1f;如何修正&a…

MAC OS X 10.9.X下用命令行开启SSD trim的方法汇总

From: http://www.jb51.net/os/MAC/238531.html 网上有很多MAC OS X开启trim的教程&#xff0c;但都是老系统的了&#xff0c;并不支持现在的10.9.X版本&#xff0c;经过一番研究&#xff0c;终于找到了开启的新方法&#xff0c;这里分享给大家网上搜的好多都是以前的老方法&a…

简单话题:LED呼吸灯和串口LED指示灯

最近在串口发送引脚上接LED指示发送或者接收状态&#xff0c;但是需求是希望连续发送或者接收字符过程中LED闪烁&#xff0c;而不是保持在一个常量或者常灭的状态。首先&#xff0c;把实际电路图和串口时序贴出来: 可以看出串口发送接收空闲态为高电平&#xff0c;只要进行数据…

Mac OS X 10.10.3对SSD开启Trim功能

From: http://bbs.pcbeta.com/viewthread-1515756-1-1.html 环境&#xff1a; SSD: Mac OS X 10.10.3 混合硬盘(普通机械硬盘8GB SSD): Win7 Mac OS X10.10.3 直接修改Clover配置文件config.plist&#xff0c;找到对应地方进行修改&#xff1a; <key>KernelAndKextPat…

关于Binder的点点滴滴(二)

http://www.linuxidc.com/Linux/2011-07/39271p2.htm4、Binder协议 Binder协议基本格式是&#xff08;命令数据&#xff09;&#xff0c;使用ioctl(fd, cmd, arg)函数实现交互。其中cmd传递命令&#xff0c;arg传递参数&#xff0c;不同的命令需要传递的参数不同。4、1 Binder所…

Unable to execute dex: Multiple dex files define 解决方法

程序编译正常&#xff0c;在用Eclipse调试执行时&#xff0c;报错 Unable to execute dex: Multiple dex files define&#xff0c;总结了一下出现问题的场景&#xff0c;并根据以下使用场景进行分类。 如果是jar包添加或者引用问题&#xff0c;那么可以尝试&#xff1a; 方法…

(四面体)CCPC网络赛 HDU5839 Special Tetrahedron

1 CCPC网络赛 HDU5839 Special Tetrahedron2 题意&#xff1a;n个点&#xff0c;选四个出来组成四面体&#xff0c;要符合四面体至少四条边相等&#xff0c;若四条边相等则剩下两条边不相邻&#xff0c;求个数3 思路&#xff1a;枚举四面体上一条线&#xff0c;再找到该线两个端…

mac下使用sshpass实现ssh记住密码

From: http://tinyhema.iteye.com/blog/2093795 由于有一些场景不能使用ssh私钥来实现免登&#xff0c;因此需要想其它办法解决一下这个问题。 安装sshpass 试图使用homebrew安装 Shell代码 $ brew install sshpass Error: No available formula for sshpass We wont …