八皇后问题详细另类图解-九张图带你了解什么是八皇后问题

2023-10-15 07:20

本文主要是介绍八皇后问题详细另类图解-九张图带你了解什么是八皇后问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


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


当我们面对这个问题时,我们可以先将这个问题简化成“四兄弟不洗jio”问题

话说很久很久以前,有四个兄弟不爱洗脚。每当晚上在从床上睡觉时,总会出现各种问题,床是4*4的方格。每行格子只能睡一个。为了防止脚气,每人不能睡在前面所有大哥的头顶和斜线上面。

在这里插入图片描述

1. 首先老大上床睡觉,就睡在了(0,0)的位置,于是乎他的头顶和斜方向是不允许有小弟睡的!(蓝色线条杠掉的位置)

在这里插入图片描述

2. 老二拖着不洗的大脚丫子也来了,首先他躺在了小a位置,他的老大一抬头就嗅到了挑衅的气息,于是老二乖乖的换到了小b的位置。老大翻了个身,抬头一看,一看还是老二的大臭脚丫子,老二一看形势还是不妙,赶快跑到了小c位置,于是老大终于可以安心睡觉了。当然老二的头顶和斜对角也是不能有人的。
在这里插入图片描述

3. 老三也来了,此时老三的头上出现了三个大大的问号???
小声嘀咕道:“你们都睡着这么香,小弟我该睡哪里??”
于是老三叫醒了老二:“哥,你要不往旁边挪挪?”
老二一看老大:“这左边两个位置我是不敢违背老大,我往右边移动一位吧”

在这里插入图片描述
于是乎,老三在不敢违背老大老二的情况下躺在了(2,1)的位置
在这里插入图片描述
4. 此时,老四终于来了,和老三一样,他头上也冒出了大大的问号??
在这里插入图片描述
于是老四叫醒老三
老四:“三哥,你动动呗,给我个位置”
老三:“我的位置都是二哥挪窝了我才有的,二哥醒醒,你再挪个窝呗”
老二:“???我都到床边了,你还要我挪窝???老大醒醒,你不动老四睡不了啊”
老大:“好了,我挪挪就是了”
于是

在这里插入图片描述
老二按着顺序一看只能睡在最后一个位置了
在这里插入图片描述
老三按顺序一瞅,第一个位置就可以,也躺下了
在这里插入图片描述
老四挨着看,第一个位置不行,得把老三熏死。一看第二个位置,老大在下面,惹不起惹不起。于是来到第三个位置,这个位置就挺好,前面的大哥都惹不着,也躺下了。
在这里插入图片描述
有了上面的过程,我们可以较为清晰的了解到每一次四兄弟协调调整睡觉位置的方式,将他拓展到“八兄弟问题”也是可以的。每当某个兄弟找不到睡觉的地方时,就叫醒他的顶头大哥,看他的顶头大哥能不能挪个窝,方便他找位置,当他的顶头大哥的位置都找完也不能使他有个窝睡觉时,他的顶头大哥就叫醒他的顶头大哥,如此达到一个回溯的效果。

下面是代码实现

package com.algorithm;/*** 2020年3月17日下午5:45:40* * @作者:小何同学* @类说明:八皇后问题 * */
public class Queen {int max = 8; // 皇后数量(兄弟数量)static int count = 0; // 保存总共有多少种可能int[] array = new int[max];// 保存每种可能的解决方法public static void main(String[] args) {// TODO Auto-generated method stubQueen queen = new Queen();queen.check(0);System.out.println(count);}// 递归private void check(int n) {//以n为标志点,保证递归的结束位置// 递归结束的标志if (n == max) {print();return;}for (int i = 0; i < max; i++) {array[n] = i;if (judge(n)) {check(n + 1);}}}private boolean judge(int n) {//判断床位是否符合规范for (int i = 0; i < n; i++) {// array[i] == array[n]表示不能在一列// Math.abs(n - i) == Math.abs(array[n] - array[i])表示不能在一斜线//特别注意的是array一维数组要理解成坐标,以数数组下标为Y值(第几个兄弟),数组值为X值(第几个床位)(这里兄弟和床位都从0开始)if (array[i] == array[n] || Math.abs(n - i) == Math.abs(array[n] - array[i])) {return false;}}return true;}private void print() {// 打印函数count++;for (int i = 0; i < array.length; i++) {System.out.print(array[i] + " ");}System.out.println();}
}

在这里插入图片描述

这篇关于八皇后问题详细另类图解-九张图带你了解什么是八皇后问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/216210

相关文章

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

Java操作PDF文件实现签订电子合同详细教程

《Java操作PDF文件实现签订电子合同详细教程》:本文主要介绍如何在PDF中加入电子签章与电子签名的过程,包括编写Word文件、生成PDF、为PDF格式做表单、为表单赋值、生成文档以及上传到OB... 目录前言:先看效果:1.编写word文件1.2然后生成PDF格式进行保存1.3我这里是将文件保存到本地后

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用