Leetcode面试经典150题-36-有效数独升级版-37.解数独

解法都在代码里,不懂就留言或者私信,比第一题稍微难点

java 复制代码
public static void solveSudoku(char[][] board) {
        /**定义三个二维数组分别代表行、列、桶(每9个格子)*/
        boolean[][] rowExists = new boolean[9][10];
        boolean[][] colExists = new boolean[9][10];
        boolean[][] bucketExists = new boolean[9][10];
        /**根据原始board初始化三个是否存在的二维数组*/
        initArrays(board, rowExists, colExists, bucketExists);
        process(board, rowExists, colExists, bucketExists, 0, 0);
    }

    private static boolean process(char[][] board, boolean[][] rowExists, boolean[][] colExists, boolean[][] bucketExists, int curRow, int curCol) {
        /**我们是按照行从下到上填的,一行填完才填下一行,如果行越界了,说明正常范围内的行都填完了*/
        if(curRow == 9) {
            return true;
        }
        /**如果当前的位置可以填,那下个位置填啥,nextRow和nextCol表示下个要填的位置的行和列*/
        int nextRow = curCol == 8? curRow + 1 : curRow;
        int nextCol = curCol == 8? 0 : curCol + 1;
        /**当前位置填过了就继续填下一个*/
        if(board[curRow][curCol] != '.') {
            return process(board, rowExists, colExists, bucketExists, nextRow, nextCol);
        } else {
            /**当前位置可以填就填,那我们填哪些呢?所有的目前符合的(行列桶都不违规)都可以试试*/
            for(char c = '1'; c <= '9'; c++) {
                int num = c - '0';
                int bucketNum = (curRow/3) * 3 + curCol / 3;
                /**行、列、桶任意一个存在就不能填*/
                if(rowExists[curRow][num] || colExists[curCol][num] || bucketExists[bucketNum][num]) {
                    continue;
                }
                board[curRow][curCol] = c;
                /**填完之后行、列、桶做标记*/
                rowExists[curRow][num] = true;
                colExists[curCol][num] = true;
                bucketExists[bucketNum][num] = true;
                /**如果后面的过程尝试正确就直接返回,否则不处理*/
                if(process(board, rowExists, colExists, bucketExists, nextRow, nextCol)) {
                    return true;
                }
                /**不成功一定要恢复现场*/
                board[curRow][curCol] = '.';
                rowExists[curRow][num] = false;
                colExists[curCol][num] = false;
                bucketExists[bucketNum][num] = false;

            }
        }
        /**如果中间过程都没有返回,返回false*/
        return false;
    }

    /**遍历board初始化是否存在的数组*/
    private static void initArrays(char[][] board, boolean[][] rowExists, boolean[][] colExists, boolean[][] bucketExists) {
        for(int i = 0; i < board.length; i++) {
            for(int j = 0; j < board[i].length; j++) {
                if(board[i][j] == '.') {
                    continue;
                }
                int num = board[i][j] - '0';
                int bucketNum = (i / 3) * 3 + j / 3;
                rowExists[i][num] = true;
                colExists[j][num] = true;
                bucketExists[bucketNum][num] = true;
            }
        }
    }

运行结果:

相关推荐
海南java第二人7 分钟前
深入剖析AQS:Java并发编程的核心基石与底层实现原理
java
趁月色小酌***8 分钟前
JAVA 知识点总结3
java·开发语言·python
fufu031113 分钟前
Linux环境下的C语言编程(五十二)
java·linux·c语言
YGGP16 分钟前
【Golang】LeetCode 416. 分割等和子集
算法·leetcode
BD_Marathon21 分钟前
Spring是什么
java·后端·spring
我命由我1234523 分钟前
Android 消息机制 - Looper(Looper 静态方法、Looper 静态方法注意事项、Looper 实例方法、Looper 实例方法注意事项)
android·java·android studio·安卓·android jetpack·android-studio·android runtime
月明长歌26 分钟前
【码道初阶】Leetcode138:随机链表的复制:用 HashMap 做深拷贝的标准解法
java·数据结构·算法·leetcode·链表·哈希算法
.简.简.单.单.29 分钟前
Design Patterns In Modern C++ 中文版翻译 第八章 组合
java·c++·设计模式
七夜zippoe40 分钟前
Spring MVC请求处理流程源码分析与DispatcherServlet核心逻辑
java·spring·mvc·过滤器·拦截器
笙枫42 分钟前
Agent 进阶设计:状态管理、中间件与多Agent协作
java·服务器·python·ai·中间件