37. 解数独
编写一个程序,通过已填充的空格来解决数独问题。
一个数独的解法需遵循如下规则:
- 数字 1-9 在每一行只能出现一次。
- 数字 1-9 在每一列只能出现一次。
- 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。
空白格用 ‘.’ 表示。
一个数独。
答案被标成红色。
Note:
- 给定的数独序列只包含数字 1-9 和字符 ‘.’ 。
- 你可以假设给定的数独只有唯一解。
- 给定数独永远是 9x9 形式的。
实现代码
class Solution {
typedef pair<int, int> space;
public:
bool visr[9][10];
bool visc[9][10];
bool visq[3][3][10];
bool isFind;
vector<space> spaces;
int cnt;
void dfs(vector<vector<char>>& board, int cnt){
if(cnt == spaces.size()) {
isFind = true;
return;
}
int i = spaces[cnt].first, j = spaces[cnt].second;
for(int k = 1; k <= 9 && !isFind; k++){
if(visr[i][k] || visc[j][k] || visq[i /3][j / 3][k]) continue;
visr[i][k] = visc[j][k] = visq[i /3][j / 3][k] = true;
board[i][j] = char('0' + k);
dfs(board, cnt + 1);
visr[i][k] = visc[j][k] = visq[i /3][j / 3][k] = false;
}
}
void solveSudoku(vector<vector<char>>& board) {
for(int i = 0; i < 9; i++){
for(int j = 0; j < 9; j++){
if(board[i][j] != '.'){
visr[i][board[i][j] - '0'] = true;
visc[j][board[i][j] - '0'] = true;
visq[i / 3][j / 3][board[i][j] - '0'] = true;
}
else spaces.push_back(space(i, j));
}
}
isFind = false;
dfs(board, 0);
}
};