蓝桥杯 Java 试题 基础练习 2n皇后问题

试题 基础练习 2n皇后问题

资源限制

时间限制:1.0s 内存限制:512.0MB

问题描述

给定一个n*n的棋盘,棋盘中有一些位置不能放皇后。现在要向棋盘中放入n个黑皇后和n个白皇后,使任意的两个黑皇后都不在同一行、同一列或同一条对角线上,任意的两个白皇后都不在同一行、同一列或同一条对角线上。问总共有多少种放法?n小于等于8。

输入格式

输入的第一行为一个整数n,表示棋盘的大小。
  接下来n行,每行n个0或1的整数,如果一个整数为1,表示对应的位置可以放皇后,如果一个整数为0,表示对应的位置不可以放皇后。
输出格式
  输出一个整数,表示总共有多少种放法。

样例输入

4
1 1 1 1
1 1 1 1
1 1 1 1
1 1 1 1

样例输出

2

样例输入

4
1 0 1 1
1 1 1 1
1 1 1 1
1 1 1 1

样例输出

0

import java.util.Scanner;


public class 二N皇后问题 {

	static int map[][];//存储地图
	static int ans=0;//计算方法
	static int n;//地图的大小
	
	public static boolean judge(int cur,int i,int color){
		for(int j=cur-1;j>=0;j--){//判断同一列是否有相同颜色的皇后
			if(map[j][i]==color){
				return false;
			}
		}
		for(int j=cur-1,z=i-1;j>=0&&z>=0;j--,z--){//判断对角线左侧是否有相同颜色的皇后
			if(map[j][z]==color){
				return false;
			}
		}
		for(int j=cur-1,z=i+1;j>=0&&z<n;j--,z++){//判断对角线右侧是否有相同颜色的皇后
			if(map[j][z]==color){
				return false;
			}
		}
		return true;
	}
	
	public static void dfs(int cur,int color){
		if(cur==n){//代表黑色放完了
			if(color==2){
				dfs(0,3);
			}
			else{
				ans++;	
			}
			return ;
		}
		for(int i=0;i<n;i++){
			if(map[cur][i]==1&&judge(cur,i,color)){
				map[cur][i]=color;
				dfs(cur+1,color);
				map[cur][i]=1;//状态恢复
			}
		}
		return;
	}
	
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc=new Scanner(System.in);
		n=sc.nextInt();
		map=new int[n][n];
		for(int i=0;i<n;i++){
			for(int j=0;j<n;j++){
				map[i][j]=sc.nextInt();
			}
		}
		dfs(0,2);//2为黑色,3为白色
		System.out.println(ans);
	}
/*
4
1 1 1 1
1 1 1 1
1 1 1 1
1 1 1 1
*/

}

总结

1.n皇后问题主要就是回溯和递归的思想。

2.要注意初始化的问题

map=new int[n][n];
//这里要现在最前面声明静态变量static int map[][];
//然后再main函数里对他进行初始化,不能写成map[][]=new int[n][n];

还有这里

static int ans=0;//计算方法

ans要在最前面初始化为0.

3.然后就是要把状态恢复了,差不多就是这样

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值