数独的Java版解法

最近偶尔有玩数独,有的题太复杂了不好解,刚好看到LeetCode上有这样的题,就尝试写了个Java的解法。

1. 数独介绍

数独盘面是个九宫,每一宫又分为九个小格。在这八十一格中给出一定的已知数字和解题条件,利用逻辑和推理,在其他的空格上填入1-9的数字。使1-9每个数字在每一行、每一列和每一宫中都只出现一次,所以又称“九宫格”。

左边是数独的题目,右边是完成后的结果。
数独题目 数独解法

2. 求解思路

2.1 方法定义与初始化

传入的是一个char[9][9]的数组,其中空白的部分用点号’.’代替,算出的解直接填进去即可。

public void solveSudoku(char[][] board)

我定义了一个Map<Integer, List<Character>> unsolve,它的key是当前未得到解的格子下标(从左上角开始到右下角分别是0-80),它的value是该格子可能的数值。

定义了一个初始化方法,用于初始化上面的那个map,即将每个未得到解的格子的可能数字填入1-9这9个数字。

private Map<Integer, List<Character>> initUnsolveMap(char[][] board) {
    Map<Integer, List<Character>> unsolve = new TreeMap<>();
    final List<Character> initChars = Arrays.asList('1', '2', '3', '4', '5', '6', '7', '8', '9');
    for (int y = 0; y < board.length; y++) {
        char[] chars = board[y];
        for (int x = 0; x < chars.length; x++) {
            char aChar = chars[x];
            if (aChar == '.') {
                unsolve.put(y * 9 + x, new ArrayList<>(initChars));
            }
        }
    }
    return unsolve;
}

当这个map的某个key的值只有一个元素时&#x

  • 5
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的数独Java代码实现: ```java public class SudokuSolver { private int[][] board; public SudokuSolver(int[][] board) { this.board = board; } public boolean solve() { for (int row = 0; row < 9; row++) { for (int col = 0; col < 9; col++) { if (board[row][col] == 0) { for (int num = 1; num <= 9; num++) { if (isValid(row, col, num)) { board[row][col] = num; if (solve()) { return true; } else { board[row][col] = 0; } } } return false; } } } return true; } private boolean isValid(int row, int col, int num) { for (int i = 0; i < 9; i++) { if (board[row][i] == num || board[i][col] == num) { return false; } } int boxRow = row - row % 3; int boxCol = col - col % 3; for (int i = boxRow; i < boxRow + 3; i++) { for (int j = boxCol; j < boxCol + 3; j++) { if (board[i][j] == num) { return false; } } } return true; } public void printBoard() { for (int row = 0; row < 9; row++) { for (int col = 0; col < 9; col++) { System.out.print(board[row][col] + " "); } System.out.println(); } } public static void main(String[] args) { int[][] board = { {3, 0, 6, 5, 0, 8, 4, 0, 0}, {5, 2, 0, 0, 0, 0, 0, 0, 0}, {0, 8, 7, 0, 0, 0, 0, 3, 1}, {0, 0, 3, 0, 0, 0, 0, 2, 0}, {9, 0, 0, 8, 0, 0, 0, 0, 5}, {0, 5, 0, 0, 0, 0, 6, 0, 0}, {1, 3, 0, 0, 0, 0, 2, 5, 0}, {0, 0, 0, 0, 0, 0, 0, 7, 4}, {0, 0, 5, 2, 0, 6, 3, 0, 0} }; SudokuSolver solver = new SudokuSolver(board); if (solver.solve()) { solver.printBoard(); } else { System.out.println("No solution found."); } } } ``` 在这个代码实现中,我们使用递归来解决数独问题。我们首先遍历整个棋盘,找到一个空格。然后,我们枚举该空格可以填入的数字,并检查该数字是否符合数独规则。如果找到一个符合规则的数字,我们将其填入该空格,然后递归地调用 solve() 方法,继续填下一个空格。如果最终我们可以填满整个棋盘,则返回 true,否则返回 false。isValid() 方法用于检查某个数字是否符合数独规则。 在 main() 方法中,我们创建了一个 9x9 的数独棋盘,并将其传递给 SudokuSolver 对象。然后,我们调用 solve() 方法来解决数独问题,并打印解决方案。注意,这里我们没有检查数独问题是否有唯一解。如果有多个解,我们只会找到其中一个。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值