领扣LintCode问题答案-33. N皇后问题

领扣LintCode问题答案-33. N皇后问题

33. N皇后问题

n皇后问题是将n个皇后放置在n*n的棋盘上,皇后彼此之间不能相互攻击(任意两个皇后不能位于同一行,同一列,同一斜线)。

给定一个整数n,返回所有不同的n皇后问题的解决方案。

每个解决方案包含一个明确的n皇后放置布局,其中“Q”和“.”分别表示一个女王和一个空位置。

样例 1:

输入:1
输出:
[[“Q”]]

样例 2:

输入:4
输出:
[
// Solution 1
[".Q…",
“…Q”,
“Q…”,
“…Q.”
],
// Solution 2
["…Q.",
“Q…”,
“…Q”,
“.Q…”
]
]

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class Solution {
	/*
	 * @param n: The number of queens
	 * @return: All distinct solutions
	 */
	public List<List<String>> solveNQueens(int n) {
		// write your code here
		int[] map = new int[n];
		Arrays.fill(map, -1);
		List<List<String>> ret = new ArrayList<>();
		this.solveNQueens(map, 0, ret);

		return ret;
	}

	private void solveNQueens(int[] map, int rowIndex, List<List<String>> ret) {
		if (rowIndex == map.length) {
			List<String> oneRet = new ArrayList<>();
			for (int r = 0; r < map.length; r++) {
				StringBuilder sb = new StringBuilder();
				for (int c = 0; c < map.length; c++) {
					if (map[r] == c) {
						sb.append("Q");
					} else {
						sb.append(".");
					}
				}
				oneRet.add(sb.toString());
			}
			ret.add(oneRet);
			return;
		}

		for (int c = 0; c < map.length; c++) {
			if (this.isValid(map, rowIndex, c)) {
				map[rowIndex] = c;
				this.solveNQueens(map, rowIndex + 1, ret);
			}
		}

		map[rowIndex] = -1;
	}

	private boolean isValid(int[] map, int rowIndex, int columnIndex) {
		for (int r = 0; r < rowIndex; r++) {
			if (map[r] == columnIndex) {
				return false;
			}
			if (Math.abs(rowIndex - r) == Math.abs(columnIndex - map[r])) {
				return false;
			}
		}

		return true;
	}
}

原题链接点这里

鸣谢

非常感谢你愿意花时间阅读本文章,本人水平有限,如果有什么说的不对的地方,请指正。
欢迎各位留言讨论,希望小伙伴们都能每天进步一点点。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

二当家的白帽子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值