题目链接: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 '.'.

Note:

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

这道题的要求是检测数独是否有效,其中空位置用‘.’填充,部分填充的只检测有数字的部分。

这道题比较简单,可以使用3个数组记录每行、每列、每个九宫格出现过的数字,然后遍历数独的数组即可。遇到数字时,检测对应行、对应列以及对应九宫格是否已经出现过该数字,如果出现,返回false;否则,将对应行、对应列以及对应九宫格的该数字位置标记为1。

时间复杂度:O(n2)

空间复杂度:O(n2)

 1 class Solution
 2 {
 3 public:
 4     bool isValidSudoku(vector<vector<char> > &board)
 5     {
 6         int used1[9][9] = {0}, used2[9][9] = {0}, used3[9][9] = {0};
 7         
 8         for(int i = 0; i < board.size(); ++ i)
 9             for(int j = 0; j < board[i].size(); ++ j)
10                 if(board[i][j] != '.')
11                 {
12                     int num = board[i][j] - '0' - 1, k = i / 3 * 3 + j / 3;
13                     if(used1[i][num] || used2[j][num] || used3[k][num])
14                         return false;
15                     used1[i][num] = used2[j][num] = used3[k][num] = 1;
16                 }
17         
18         return true;
19     }
20 };