八皇后问题

红框代表皇后,一共有92种排法

java代码实现如下

package leetcode;

public class EightQueen {
static int count = 0;// 记录第几种

public static void main(String[] args) {
	int[][] cotent = new int[8][8];
	eightQueen(0, cotent);
}

public static boolean noDanger(int row, int col, int[][] arr) {
	//只需判断上、左上、右上方
	// 上
	for (int r = row-1; r >= 0; r--) {
		if (arr[r][col] == 1) {
			return false;
		}
	}
	// 左上
	for (int r = row-1, c = col-1; r >= 0 && c >= 0; r--, c--) {
		if (arr[r][c] == 1) {
			return false;
		}
	}
	// 右上
	for (int r = row-1, c = col+1; r >= 0 && c < arr[0].length; r--, c++) {
		if (arr[r][c] == 1) {
			return false;
		}
	}
	return true;
}

public static void eightQueen(int row, int[][] arr) {
	if (row == 8) {
		//当8行都有皇后的时候说明满足条件
		System.out.println("第" + (++count) + "种");
		for (int i = 0; i < arr.length; i++) {
			for (int j = 0; j < arr[i].length; j++) {
				System.out.print(arr[i][j] + " ");
			}
			System.out.println();
		}
	} else {
		int[][] newArr = new int[8][8];
		for (int i = 0; i < arr.length; i++) {
			for (int j = 0; j < arr[i].length; j++) {
				newArr[i][j] = arr[i][j];
			}
		}
		//每一行从左到右检查
		for (int col = 0; col < 8; col++) {
			
			if (noDanger(row, col, newArr)) {
				for (int c = 0; c < 8; c++) {
					newArr[row][c] = 0;
				}
				newArr[row][col] = 1;
				//上一行有皇后就进入下一行检查
				eightQueen(row + 1, newArr);
			}
		}
	}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值