LeetCode(37)

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;
    }
};

 

上一篇:[HIve - LanguageManual] Joins


下一篇:vs2010编译error_code