LeetCode --- 36. Valid Sudoku

2015-07-20 17:20:19 · 作者: · 浏览: 5

题目链接: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
   
     > &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 };
   

转载请说明出处:LeetCode --- 36. Valid Sudoku