一、八皇后问题介绍
1、代码
package com.rf.springboot01.dataStructure.recursion;
/**
* @description: 使用递归实现八皇后问题
* @author: xiaozhi
* @create: 2020-08-02 21:13
*/
public class LabyrinthTest {
int max =8;//定义一个max表示一共有多少个皇后
int[] array=new int[max];//定义一个数组,存储皇后放置位置的结果
static int judgeCount = 0;
static int count = 0;
public static void main(String[] args) {
LabyrinthTest labyrinthTest=new LabyrinthTest();
labyrinthTest.check(0);
System.out.printf("一共有%d解法", count);
System.out.println();
System.out.printf("一共判断冲突的次数%d次", judgeCount); // 1.5w
}
/**
* @Description: 放置第n个皇后
* @Param: n 表示第n个皇后
* @Author: xz
* @return:
* @Date: 2020/8/2 21:24
*/
private void check(int n){
if(n==max){ //n = 8 , 表示一共8个皇后,第8个皇后已经放好位置
print();
return;
}
//依次放入皇后,并判断是否冲突
for(int i=0;i
关注
打赏
热门博文
- Netty——网络编程 NIO(Selector处理accept事件)代码示例
- CompletableFuture异步编排(多任务组合)
- CompletableFuture异步编排(线程串行化代码示例)
- CompletableFuture异步编排(handle最终处理)
- CompletableFuture异步编排(计算完成回调代码示例)
- hutool工具导出excel代码示例
- java 获取音频、视频文件时长代码示例
- PostMan发送请求参数带有路径特殊字符会返回400错误(与URL字符及URL编码值有关)
- Rabbitmq与Erlang安装包下载图解
- idea2021.1版本SpringBoot项目日志的说明及使用