Valid Sudoku

Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules.

The Sudoku board could be partially filled, where empty cells are filled with the character '.'.


A partially filled sudoku which is valid.

Note:
A valid Sudoku board (partially filled) is not necessarily solvable. Only the filled cells need to be validated.

class Solution {
public:
    bool isValidSudoku(vector<vector<char> > &board) {
        bool exist[10];
        //check row
        for(int i=0;i<9;i++)
        {
            for(int k=0;k<9;k++) exist[k+1]=false;;
            for(int j=0;j<9;j++)
            if(board[i][j]!='.')
            {
                 if(exist[board[i][j]-'0']) return false;
                 exist[board[i][j]-'0']=true;
            }
        }
        //check column
        for(int i=0;i<9;i++)
        {
            for(int k=0;k<9;k++) exist[k+1]=false;
            for(int j=0;j<9;j++)
            if(board[j][i]!='.')
            {
                 if(exist[board[j][i]-'0']) return false;
                 exist[board[j][i]-'0']=true;
            }
        }
        //check square
        for(int di=0;di<9;di+=3)
            for(int dj=0;dj<9;dj+=3)
            {
                for(int k=0;k<9;k++) exist[k+1]=false;
                for(int i=0;i<3;i++)
                    for(int j=0;j<3;j++)
                    {
                        char c=board[di+i][dj+j];
                        if(c!='.')
                        {
                            if(exist[c-'0']) return false;
                            exist[c-'0']=true;
                        }
                    }
            }
        return true;
    }
}; 

posted @ 2014-05-29 16:02  erictanghu  阅读(122)  评论(0编辑  收藏  举报