Leetcode08.12 N皇后
public List<List<String>> solveNQueens(int n) { //棋盘 char[][] board = new char[n][n]; //结果集合 List<List<String>> reList = new LinkedList<List<String>>(); setQueen(0, n, board, reList); return reList; } //回溯函数,逐行放置皇后 private final void setQueen(int x, int boardLen, char[][] board, List<List<String>> reList) { if (x == boardLen) { reList.add(boardToString(board, boardLen)); return; } for (int i = 0; i < boardLen; i++) { if (!canSet(x, i, boardLen, board)) { continue; } board[x][i] = 'Q'; setQueen(x + 1, boardLen, board, reList); board[x][i] = '.'; } } //判断 x,y 坐标是否可以放置皇后 private final boolean canSet(int x, int y, int boardLen, char[][] board) { for (int i = 0; i <= x; i++) { //判断竖线 if (board[i][y] == 'Q') { return false; } int point = x - i; //判断左下对角线 if (inBoard(i, y - point, boardLen) && (board[i][y - point] == 'Q')) { return false; } //判断右下对角线 if (inBoard(i, y + point, boardLen) && board[i][y + point] == 'Q') { return false; } } return true; } //判断 x,y 坐标是否在棋盘内 private final boolean inBoard(int x, int y, int boardLen) { if (x >= 0 && y >= 0 && x < boardLen && y < boardLen) { return true; } return false; } //将棋盘转为 String 集合 private final List<String> boardToString(char[][] board, int boardLen) { List<String> re = new ArrayList<String>(boardLen); for (int i = 0; i < boardLen; i++) { StringBuilder sb = new StringBuilder(); for (int j = 0; j < boardLen; j++) { char ch = board[i][j] == 'Q' ? 'Q' : '.'; sb.append(ch); } re.add(sb.toString()); } return re; }
当你看清人们的真相,于是你知道了,你可以忍受孤独
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构