一、八皇后问题介绍
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
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?