设为首页 加入收藏

TOP

LeetCode --- 36. Valid Sudoku
2015-07-20 17:20:19 来源: 作者: 【 】 浏览:3
Tags:LeetCode --- 36. Valid Sudoku

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

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇LeetCode --- 38. Count and Say 下一篇POJ 2195 Going Home

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Redis on AWS:Elast (2025-12-27 04:19:30)
·在 Spring Boot 项目 (2025-12-27 04:19:27)
·使用华为开发者空间 (2025-12-27 04:19:24)
·Getting Started wit (2025-12-27 03:49:24)
·Ubuntu 上最好用的中 (2025-12-27 03:49:20)