首页 > 其他 > 详细

leetcode-----37. 解数独

时间:2020-06-27 17:04:54      阅读:49      评论:0      收藏:0      [点我收藏+]

代码

class Solution {
public:
    bool row[9][9], col[9][9], cell[3][3][9];

    void solveSudoku(vector<vector<char>>& board) {
        memset(row, 0, sizeof row);
        memset(col, 0, sizeof col);
        memset(cell, 0, sizeof cell);

        for (int i = 0; i < 9; ++i) {
            for (int j = 0 ; j < 9; ++j) {
                if (board[i][j] != ‘.‘) {
                    int t = board[i][j] - ‘1‘;
                    row[i][t] = col[j][t] = cell[i / 3][j / 3][t] = true;
                }
            }
        }    
        dfs(board, 0, 0);
    }

    bool dfs(vector<vector<char>>& board, int x, int y) {
        if (y == 9) ++x, y = 0;
        if (x == 9) return true;
        if (board[x][y] != ‘.‘) return dfs(board, x, y + 1);
        for (int i = 0; i < 9; ++i) {
            if (!row[x][i] && !col[y][i] && !cell[x / 3][y / 3][i]) {
                board[x][y] = i + ‘1‘;
                row[x][i] = col[y][i] = cell[x / 3][y / 3][i] = true;
                if (dfs(board, x, y + 1)) return true;
                board[x][y] = ‘.‘;
                row[x][i] = col[y][i] = cell[x / 3][y / 3][i] = false;
            }
        }
        return false;
    }

};

leetcode-----37. 解数独

原文:https://www.cnblogs.com/clown9804/p/13198616.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!