Java实现递归回溯,解决八皇后问题,数据结构与算法

文章目录

    • 八皇后问题
    • 解决思路
    • 代码实现
    • 运行结果


八皇后问题

八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。该问题是国际西洋棋棋手马克斯·贝瑟尔于1848年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即:任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。


解决思路

①第一个皇后先放第一行第一列。

②第二个皇后放在第二行第一列、然后判断是否OK,如果不0K, 继续放在第二列、第三列、依次把所有列都放完,找到一个合适。

③继续第三个皇后, 还是第一列、第二列…直到第8个皇后也能放在一个不冲突的位置,算是找到了一个正确解。

④当得到一个正确解时,在栈回退到上一个栈时,就会开始回溯,即将第一个皇后,放到第一列的所有正确解,全部得到。

⑤然后回头继续第-一个皇后放第二列,后面继续循环执行①②③④的步骤。


代码实现

/*** @Author: Yeman* @Date: 2021-10-31-15:48* @Description:*/
public class Queue8 {int max = 8; //8个皇后int[] arr = new int[max]; //下标为第几个(即第几行),值为第几列static int count = 0; //多少个放法static int judgeCount = 0; //判断了多少次public static void main(String[] args) {Queue8 queue8 = new Queue8();queue8.check(0);System.out.printf("一共有%d种解法\n",count);System.out.printf("一共判断了%d次",judgeCount);}//用来放置第n个皇后private void check(int n){if (n == max){ //n为8相当于是第九个皇后了,说明已经全部放好了print();return;}for (int i = 0; i < arr.length; i++) {arr[n] = i;if (judge(n)){ //不冲突check(n+1);}}}//用来第n个皇后判断与前面的所有皇后是否冲突private boolean judge(int n){judgeCount++;for (int i = 0; i < n; i++) {//是否同列同斜线if (arr[i] == arr[n] || Math.abs(arr[i]-arr[n]) == Math.abs(i-n)){return false;}}return true;}//输出每一种放法private void print(){count++;for (int i = 0; i < arr.length; i++) {System.out.print(arr[i] + " ");}System.out.println();}
}

运行结果

(截取部分)

在这里插入图片描述

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

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

相关文章

HTML JS正方形轮播,js,html一个页面里面多个页面轮播

这种轮播都是div或者图片的&#xff0c;div能换成iframe显示嵌套网页吗&#xff1f;或者请问有没有其他方法能实现多个页面轮播&#xff1f;我写了三个iframeframeborder"no" border"0" marginwidth"0" marginheight"0" scrolling&quo…

html在screen检索屏幕分辨率,Electron开发之screen模块-根据屏幕分辨率设置窗口大小...

使用 Electron screen 模块可对屏幕进行相关操做screen 模块检索屏幕的 size&#xff0c;显示&#xff0c;鼠标位置等的信息,在 app 模块的ready 事件触发以前不可以使用这个模块.html注意: 在渲染进程 / 开发者工具栏, window.screen 是一个预设值的 DOM 属性, 因此这样写 var…

html制作任务计划列表网页,添加计划任务的脚本

在windows中怎样用bat或者vbs添加计划任务..例如.我想在每次开机10分钟后运行windows目录中的XX.exe文件。应该怎么弄写了一个bat的备份脚本&#xff0c;在添加计划任务的时候&#xff0c;出你可以把 运行的帐号制定成管理员&#xff0c;不要任意用户。200分。用批处理或DOS添加…

使用Travis-CI的SpringBoot应用程序的CI / CD

在本文中&#xff0c;我们将学习如何将Travis CI用于SpringBoot应用程序的持续集成和持续部署&#xff08;CI / CD&#xff09;。 我们将学习如何运行Maven构建目标&#xff0c;使用JaCoCo插件&#xff0c;使用SonarCloud代码质量检查&#xff0c;建立泊坞窗图像进行测试覆盖率…

第一章MCS-51单片机结构,单片机原理、接口及应用

文章目录一、MCS-51单片机内部结构二、CPU三、存储器四、特殊功能寄存器SFR五、时钟电路与复位电路六、引脚功能一、MCS-51单片机内部结构 单片机是在一块芯中集成了CPU、RAM、ROM、定时/计数器和多功能I/O接口等基本部件的大规模集成电路&#xff0c;又称MCU。 51系列单片机…

微信小程序云开发校园社交二手物品跳蚤平台表白动态求助寻物组队

前些天发现了十分不错的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;没有广告&#xff0c;分享给大家&#xff0c;大家可以自行看看。&#xff08;点击跳转人工智能学习资料&#xff09; 微信公众号&#xff1a;创享日记&#xff08;微信号csds99202…

html悬浮弹窗后面背景变深,JS+CSS实现Div弹出窗口同时背景变暗的方法

本文实例讲述了JSCSS实现Div弹出窗口同时背景变暗的方法。分享给大家供大家参考。具体实现方法如下&#xff1a;代码如下:JSCSS实现的Div弹出窗口&#xff0c;同时背景变暗function locking(){document.all.ly.style.display"block";document.all.ly.style.widthd…

传感与检测实验报告,差动变压器的特性测定,江南大学物联网自动化

前些天发现了十分不错的人工智能学习电子书&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;没有广告&#xff0c;分享给大家&#xff0c;大家可以自行看看。&#xff08;点击跳转人工智能学习资料&#xff09; public class LeastSquares {public static void matching(…

计算机网络由 子网,计算机网络系统是由通信子网和资源子网组成的。()

计算机网络系统是由通信子网和资源子网组成的。()更多相关问题“May I speak to Iris&#xff1f;” “This is () speaking.”用FDI提出的二位数字法记录的牙位24指的是凡在一个登记期内有&#xff1a;伪造学历和出版专业工作资历证明、脱离出版专业技术岗位_______年、因违法…

如何使用Spring初始化程序创建Spring Boot项目

你好朋友&#xff0c; 如果您以前使用过Spring框架&#xff0c;则必须意识到&#xff0c;即使要开始使用基本的Spring功能也需要付出一些真正的努力。有了Spring Boot&#xff0c;最初的麻烦就消失了&#xff0c;您可以在数分钟内开始使用。 欢迎来到Spring Boot的世界&#…

计算机组成原理,计算机系统总线,总线分类、特性、性能指标、结构以及总线控制,判优控制通信控制

文章目录总线的基本概念总线的分类总线特性及性能指标总线结构总线控制一、总线判优控制二、总线通信控制总线的基本概念 一、总线是连接各个部件的信息传输线&#xff0c;是各个部件共享的传输介质。 二、总线上信息的传送有串行和并行&#xff1a; 三、总线结构计算机举例…

虚拟机使用计算机网络,虚拟机技术在计算机网络专业课程教学中的应用

环境&#xff0c;做一些服务器配置&#xff0c;这就需要机房安装多种操作系统与多种软件&#xff0c;还需要允许学生随意的对操作环境进行配置。计算机机房的建设越来越完善&#xff0c;但需要承担的多门课程的学习和实验&#xff0c;使用率高。如若进行与操作系统配置实验&…

传感与检测技术,Pt100热电阻测温实验报告,江南大学物联网

public class LeastSquares {public static void matching(double[] x, double[] y, double[] input, double fully) {double k getK(x, y);double b getB(x, y);System.out.println("线性回归系数 k 值&#xff1a;\t" k "\n" "线性回归系数 b …

html 高度不够,HTML/CSS:Div未扩展到内容高度

我有几个未扩展的div元素以匹配其内容的高度。我已经读过&#xff0c;这可能是由浮动内容引起的;这个内容不是浮动的 - 虽然我开始觉得我应该把我的电脑扔在河里。这算不算&#xff1f;HTML/CSS&#xff1a;Div未扩展到内容高度代码&#xff1a;#interaction-options-container…

传感与检测技术,光电二极管和光敏电阻的特性研究实验报告,江南大学物联网工程学院自动化

前些天发现了十分不错的人工智能学习电子书&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;没有广告&#xff0c;分享给大家&#xff0c;大家可以自行看看。&#xff08;点击跳转人工智能学习资料&#xff09; 江南大学物联网工程学院传感与检测技术《光电二极管和光敏电…

sql 动态写入数据库字段_批处理写入,动态SQL和参数化SQL,数据库的性能如何?...

sql 动态写入数据库字段最有效的数据库优化之一是批处理写入。 批处理写入受大多数现代数据库和JDBC标准的一部分支持&#xff0c;并且受大多数JPA提供程序支持。 普通数据库访问包括在单独的数据库/网络访问中将每个DML&#xff08;插入&#xff0c;更新&#xff0c;删除&…

将HTML转换为Apache POI的RichTextString

1.概述 在本教程中&#xff0c;我们将构建一个将HTML作为输入的应用程序&#xff0c;并使用提供HTML的RichText表示形式创建Microsoft Excel工作簿。 为了生成Microsoft Excel工作簿&#xff0c;我们将使用Apache POI 。 为了分析HTML&#xff0c;我们将使用Jericho。 Github上…

计算机基础知识第3版答案,计算机基础知识试题库及答案(3)

65、计算机的CPU每执行一个__B___&#xff0c;就完成一步基本运算或判断。A、语句B、指令C、程序D、软件66、计算机能按照人们的意图自动、高速地进行操作&#xff0c;是因为采用了__A__。A、程序存储在内存B、高性能的CPUC、高级语言D、机器语言67、语言处理程序的发展经历了_…

MySQL常见问题的解决,root用户密码忘记,不是内部或外部命令,修改数据库和表的字符编码,命令行客户端的字符集问题

文章目录问题1&#xff1a;root用户密码忘记&#xff0c;重置的操作问题2&#xff1a;mysql命令报“不是内部或外部命令”问题3&#xff1a;错误ERROR &#xff1a;没有选择数据库就操作表格和数据问题4&#xff1a;命令行客户端的字符集问题问题5&#xff1a;修改数据库和表的…