判断一个 9x9 的数独是否有效。只需要根据以下规则,验证已经填入的数字是否有效即可。

  1. 数字 1-9 在每一行只能出现一次。
  2. 数字 1-9 在每一列只能出现一次。
  3. 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。

上图是一个部分填充的有效的数独。

数独部分空格内已填入了数字,空白格用 '.' 表示。

示例 1:

输入:
[
["5","3",".",".","7",".",".",".","."],
["6",".",".","1","9","5",".",".","."],
[".","9","8",".",".",".",".","6","."],
["8",".",".",".","6",".",".",".","3"],
["4",".",".","8",".","3",".",".","1"],
["7",".",".",".","2",".",".",".","6"],
[".","6",".",".",".",".","2","8","."],
[".",".",".","4","1","9",".",".","5"],
[".",".",".",".","8",".",".","7","9"]
]
输出: true

示例 2:

输入:
[
  ["8","3",".",".","7",".",".",".","."],
  ["6",".",".","1","9","5",".",".","."],
  [".","9","8",".",".",".",".","6","."],
  ["8",".",".",".","6",".",".",".","3"],
  ["4",".",".","8",".","3",".",".","1"],
  ["7",".",".",".","2",".",".",".","6"],
  [".","6",".",".",".",".","2","8","."],
  [".",".",".","4","1","9",".",".","5"],
  [".",".",".",".","8",".",".","7","9"]
]
输出: false
解释: 除了第一行的第一个数字从 5 改为 8 以外,空格内其他数字均与 示例1 相同。
但由于位于左上角的 3x3 宫内有两个 8 存在, 因此这个数独是无效的。

说明:

  • 一个有效的数独(部分已被填充)不一定是可解的。
  • 只需要根据以上规则,验证已经填入的数字是否有效即可。
  • 给定数独序列只包含数字 1-9 和字符 '.' 。
  • 给定数独永远是 9x9 形式的。

rows:看行是否有重复元素 cols:看列是否有重复元素 cube:看各个9*9是否满足题意。

int rowIndex = 3 * (i / 3);

int colIndex = 3 * (i % 3);

0 1 2 3 4 5 6 7 8

0 0 0 3 3 3 6 6 6  rowIndex

0 3 6 0 3 6 0 3 6 colIndex

0 0 0 1 1 1 2 2 2  j / 3

0 1 2 0 1 2 0 1 2  j % 3

 class Solution {
public boolean isValidSudoku(char[][] board) {
for(int i = 0;i < board.length;i++){
HashSet<Character> rows = new HashSet<>();
HashSet<Character> cols = new HashSet<>();
HashSet<Character> cube = new HashSet<>();
for(int j = 0;j < board[0].length;j++){
if(board[i][j] != '.' && !rows.add(board[i][j])) return false; //添加成功返回1
if(board[j][i] != '.' && !cols.add(board[j][i])) return false; int rowIndex = 3 * (i / 3);
int colIndex = 3 * (i % 3); if(board[rowIndex + j / 3][colIndex + j % 3] != '.' && !cube.add(board[rowIndex + j / 3][colIndex + j % 3])) return false;
}
}
return true;
}
}

2019-04-29 19:04:12

最新文章

  1. GJM : Unity3D HIAR -【 快速入门 】 四、创建 Hello World
  2. iniutils for Golang
  3. PHP类型转换
  4. mysql之常用操作
  5. 151102SQL语句
  6. BIEEE 创建多维钻取分析(4)
  7. org.apache.http.client.CircularRedirectException: Circular redirect to &quot;http://xxx&quot;问题解决
  8. 虚拟内存和swap分区的关系
  9. SQL Server 2008 表值参数用法
  10. BOM和DOM详解
  11. Masonry框架源码深度解析
  12. Redis-Nosql数据库入门
  13. Codeforces Round #382 (div2)
  14. js实现一个简单的登录页面
  15. [转]Git忽略规则及.gitignore规则不生效的解决办法
  16. 96A
  17. Java Socket NIO入门
  18. GitHub创建个人主页
  19. button设置边宽和圆角
  20. JNDI数据源(在Tomcat下配置JNDI多数据源实例)

热门文章

  1. SpringMVC最直观的流程图
  2. Windows Java安装
  3. docker运行jar文件
  4. 【JavaScript】学习中遇到的一些问题
  5. 用友畅捷通T6数据升级到T+的步骤图解
  6. oracle 11g 安装步骤
  7. DNS 本质
  8. JS对象格式化方法:pretty_format
  9. github收藏夹
  10. Exp4 恶意代码分析 20164303 景圣