题解 | Sudoku

Sudoku

https://www.nowcoder.com/practice/78a1a4ebe8a34c93aac006c44f6bf8a1

import java.util.*;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    
    static List<int[]> list;
    static int[][] arr;

    public static void main(String[] args) {

        Scanner in = new Scanner(System.in);

        arr = new int[9][9];
        list = new ArrayList<>(); // 缺失数字的格子,即:需要填充的格子

        for(int r = 0; r < 9; r++) {
            for(int c = 0; c < 9; c++) {
                arr[r][c] = in.nextInt();
                if (arr[r][c] == 0) {
                    list.add(new int[]{r,c});
                }
            }
        }

        hand(0);

        for(int r = 0; r < 9; r++) {
            for(int c = 0; c < 9; c++) {
                System.out.printf("%d ", arr[r][c]);
            }
            System.out.println();
        }
    }


    // 从 arr 的 list[index] 位置开始填充, 返回所有格子是否填充完成
    static boolean hand(int index) {
        if (index == list.size()) {
            return true;
        }

        // 枚举 1-9 每个数字来填充 arr[r][c]
        int r = list.get(index)[0];
        int c = list.get(index)[1];

        for(int num = 1; num <= 9; num++) {
            if (isValid(r, c, num)) {
                arr[r][c] = num;
                if (hand(index + 1)) {
                    return true;
                }
                arr[r][c] = 0;
            }
        }

        return false;
    }


    // arr[r][c] 是否可以填充 num
    static boolean isValid(int r, int c, int num) {
        // 检查行,若当前行 r 已存在 num,说明不能填充
        for(int col = 0; col < 9; col++) {
            if (arr[r][col] == num) {
                return false;
            }
        }

        // 检查列
        for(int row = 0; row < 9; row++) {
            if (arr[row][c] == num) {
                return false;
            }
        }

        // 检查arr[r][c] 所属的 3*3 网格
        int startRow = r / 3 * 3;
        int startCol = c / 3 * 3;
        for(int row = startRow; row < startRow + 3; row++) {
            for(int col = startCol; col < startCol + 3; col++) {
                if (arr[row][col] == num) {
                    return false;
                }
            }
        }

        return true;
    }

}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 13:15
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务