class Solution {
public:
void solveSudoku(vector<vector<char>>& board) {
for(int i=0;i<9;i++){
for(int j=0;j<9;j++){
if(board[i][j]!='.'){
mt[0][i][board[i][j]-'1'] = true;
mt[1][j][board[i][j]-'1'] = true;
flag[i][j] = true;
n++;
}
}
}
for(int i=0;i<9;i++){
for(int j=i/3*3;j<3+i/3*3;j++){
for(int k=0+i%3*3;k<3+i%3*3;k++){
if(board[j][k]!='.'){
mt[2][i][board[j][k]-'1'] = true;
}
}
}
}
addNode(board,0,0);
}
private:
int n;
bool flag[10][10],mt[3][10][10];
bool isSudoku(vector<vector<char>>board,int p,int q,char c){
int t = nSudoku(p,q);
// cout<<p<<q<<t<<endl;
if(mt[0][p][c-'1']||mt[1][q][c-'1']||mt[2][t][c-'1'])
return false;
return true;
}
int nSudoku(int p,int q){
int i = p/3,j = q/3;
return i*3+j;
}
bool addNode(vector<vector<char>>&board,int p,int q){
if(n==81){
return true;
}
bool f2 = false,f3;
int t,i,j;
char c2;
stack<int>s1,s2;
for(i=p;i<9;i++){
f3 = false;
for(j=0;j<9;j++){
if(board[i][j]=='.'){
f3 = true;
break;
}
}
if(f3)break;
}
p = i;
q = j;
for(char c='1';c<='9';c++){
if(board[p][q]=='.'&&isSudoku(board,p,q,c)){
// cout<<p<<q<<c<<endl;
t = nSudoku(p,q);
s1.push(p);
s2.push(q);
mt[0][p][c-'1'] = mt[1][q][c-'1'] = mt[2][t][c-'1'] = true;
board[p][q] = c;
n++;
// cout<<p<<q<<endl;
if(addNode(board,p,q))return true;
c2 = board[p][q];
t = nSudoku(p,q);
// cout<<p<<" "<<q<<c2-'1'<<endl;
p = s1.top();
q = s2.top();
s1.pop();
s2.pop();
board[p][q] = '.';
mt[0][p][c2-'1'] = mt[1][q][c2-'1'] = mt[2][t][c2-'1'] = false;
n--;
}
}
return false;
}
};