Reference: LeetCode
Difficulty: Medium
Problem
Determine if a
9x9Sudoku board is valid. Only the filled cells need to be validated according to the following rules:
- Each row must contain the digits
1-9without repetition. - Each column must contain the digits
1-9without repetition. - Each of the 9
3x3sub-boxes of the grid must contain the digits1-9without repetition.
The Sudoku board could be partially filled, where empty cells are filled with the character ‘.’.
![]()
Example:
1 | Input: [ |
Note:
- A Sudoku board (partially filled) could be valid but is not necessarily solvable.
- Only the filled cells need to be validated according to the mentioned rules.
- The given board contain only digits
1-9and the character'.'. - The given board size is always
9x9.
Analysis
Hash Set
Check three cases respectively.
1 | public boolean isValidSudoku(char[][] board) { |
Time: $O(1)$
Space: $O(1)$
Or, we can use 27 hash set to achieve one-pass solution.
1 | Set<Integer> [] rows = new HashSet[9]; |