Leetcode: 36. Valid Sudoku

Description

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 X 3 的小格子不能出现重复
  • 用多个bitset<9>做映射,该位置0表未出现该数字,该位置1表出现
  • 然后将9行,9列,9个小矩阵映射到27个bitset<9>上面

代码

  • O(n^2)
class Solution {
public:
   bool isValidSudoku(vector<vector<char>>& board) {
		int m = board.size();
		int n = board[0].size();

		vector<bitset<9>> flag(27, 0);
		int num = 0;
		for (int i = 0; i < m; ++i){
			for (int j = 0; j < n; ++j){
				if (board[i][j] == '.') continue;
				else{
					num = board[i][j] - '1';
					if (flag[i].test(num) || flag[9 + j].test(num) || flag[18 + (i / 3) * 3 + j / 3].test(num)) 
						return false;
					else {
						flag[i].set(num);
						flag[9 + j].set(num);
						flag[18 + (i / 3) * 3 + j / 3].set(num);
					}
				}
			}
		}

		return true;
	}
};
posted @ 2017-05-10 22:48  JeffLai  阅读(142)  评论(0编辑  收藏  举报