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

数字 1-9 在每一行只能出现一次。
数字 1-9 在每一列只能出现一次。
数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图)

注意:

一个有效的数独(部分已被填充)不一定是可解的。
只需要根据以上规则,验证已经填入的数字是否有效即可。
空白格用 ‘.’ 表示。

Determine if a 9 x 9 Sudoku board is valid. Only the filled cells need to be validated according to the following rules:

Each row must contain the digits 1-9 without repetition.
Each column must contain the digits 1-9 without repetition.
Each of the nine 3 x 3 sub-boxes of the grid must contain the digits 1-9 without repetition.
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.

提示:

board.length == 9
board[i].length == 9
board[i][j] 是一位数字(1-9)或者 ‘.’

示例 1:

输入:board =
[["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:

输入:board =

[["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 存在, 因此这个数独是无效的。

解题:(没办法太菜了,只能把官方文档拿出来)

https://leetcode.cn/problems/valid-sudoku/solutions/1001859/you-xiao-de-shu-du-by-leetcode-solution-50m6/

方法一:一次遍历
有效的数独满足以下三个条件:

  • 同一个数字在每一行只能出现一次;
  • 同一个数字在每一列只能出现一次;
  • 同一个数字在每一个小九宫格只能出现一次。

可以使用哈希表记录每一行、每一列和每一个小九宫格中,每个数字出现的次数。只需要遍历数独一次,在遍历的过程中更新哈希表中的计数,并判断是否满足有效的数独的条件即可。

对于数独的第 i 行第 j 列的单元格,其中 0≤i,j<9,该单元格所在的行下标和列下标分别为 i 和 j,该单元格所在的小九宫格的行数和列数分别为 [i/3]和[j/3],其中0<=[i/3],[j/3] < 3

由于数独中的数字范围是 1 到 9 ,因此可以使用数组代替哈希表进行计数。

具体做法是,创建二维数组 rows 和 columns分别记录数独的每一行和每一列中的每个数字的出现次数,创建三维数组 subboxes 记录数独的每一个小九宫格中的每个数字的出现次数,其中 rows[i][index]、columns[j][index]和 subboxes[i/3][j/3][index]分别表示数独的第 i 行第 j 列的单元格所在的行、列和小九宫格中,数字 index+1出现的次数,其中 0≤index<9,对应的数字 index+1满足 1≤index+1≤9。([i/3],[j/3] 需要向下取整)。

如果 board[i][j]填入了数字 n,则将 rows[i][n−1]、columns[j][n−1]和 subboxes[i3][j3⌋][n−1]各加 1 。如果更新后的计数大于 1,则不符合有效的数独的条件,返回 false。

如果遍历结束之后没有出现计数大于 1 的情况,则符合有效的数独的条件,返回 true。

leetcode:https://leetcode.cn/problems/valid-sudoku/description/

var isValidSudoku = function (board) {const rows = new Array(9).fill(0).map(() => { return new Array(9).fill(0) })//9X9const columns = new Array(9).fill(0).map(() => { return new Array(9).fill(0) })//9X9const smallBoard = new Array(3).fill(0).map(() => { return new Array(3).fill(0).map(() => { return new Array(9).fill(0) }) })// 3X3X9//9X9for (let i = 0; i < 9; i++) {for (let j = 0; j < 9; j++) {const item = board[i][j]//找到不为空的数据if (item !== '.') {//rows[i][index]、columns[j][index]和 subboxes[i/3][j/3][index]分别表示数独的第 i 行第 j 列的单元格所在的行、列和小九宫格中,数字 index+1出现的次数const index = item.charCodeAt() - "0".charCodeAt() - 1rows[i][index]++columns[j][index]++smallBoard[Math.floor(i / 3)][Math.floor(j / 3)][index]++if (rows[i][index] > 1 || columns[j][index] > 1 || smallBoard[Math.floor(i / 3)][Math.floor(j / 3)][index] > 1) {return false}}}}return true
};
var isValidSudoku = function (board) {const rows = new Array(9).fill(0).map(() => { return new Array(9).fill(0) })const columns = new Array(9).fill(0).map(() => { return new Array(9).fill(0) })const smallBoard = new Array(3).fill(0).map(() => { return new Array(3).fill(0).map(() => { return new Array(9).fill(0) }) })for (let i = 0; i < 9; i++) {for (let j = 0; j < 9; j++) {const item = board[i][j]if (item !== '.') {const index = item.charCodeAt() - "0".charCodeAt() - 1rows[i][index]++columns[j][index]++smallBoard[Math.floor(i / 3)][Math.floor(j / 3)][index]++if (rows[i][index] > 1 || columns[j][index] > 1 || smallBoard[Math.floor(i / 3)][Math.floor(j / 3)][index] > 1) {return false}}}}return true
};

36. 有效的数独(javascript)36. Valid Sudoku相关推荐

  1. leetcode 36. Valid Sudoku | 37. Sudoku Solver(数独)

    36. Valid Sudoku https://leetcode.com/problems/valid-sudoku/ 题解 class Solution {public boolean isVal ...

  2. 36. Valid Sudoku数独判断

    题目:数独填写正确判断 https://leetcode.com/problems/valid-sudoku/description/ Determine if a Sudoku is valid, ...

  3. LeetCode 36. Valid Sudoku(九宫格数独)

    依次检查每行,每列,每个子九宫格是否出现重复元素,如果出现返回false,否则返回true. 难点在于表示第i个九宫格每个格点的坐标. 观察行号规律: 第0个九宫格:000111222; 第1个九宫格 ...

  4. LeetCode 36. Valid Sudoku

    LeetCode 36. Valid Sudoku Solution1:我的答案,比较笨.但是清晰易懂好上手啊~~~ class Solution { public:bool isValidSudok ...

  5. [leetcode]36. Valid Sudoku c语言

    题目 Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules. The Sudoku board could ...

  6. leetcode:36. 有效的数独

    题目来源 leetcode:36. 有效的数独 题目描述 class Solution {public:bool isValidSudoku(vector<vector<char>& ...

  7. leetcode之Valid Sudoku有效的数独(一步步改进代码)

    题目链接:Valid Sudoku有效的数独 题目已经十分确定的说了只有1~9,因此标记法无疑是非常好的选择. 基本思路:对行.列.小数独块分别用一个size为9的数组来标记数字1~9在本行(列/块) ...

  8. leetcode 36. 有效的数独 (将 9 * 9 数独划分成 9 宫格 )

    leetcode 36. 有效的数独 判断一个 9x9 的数独是否有效.只需要根据以下规则,验证已经填入的数字是否有效即可. 数字 1-9 在每一行只能出现一次. 数字 1-9 在每一列只能出现一次. ...

  9. LeetCode刷题——36.有效的数独

    文章目录 面试刷题第二天 LeetCode刷题--36.有效的数独 1.题目描述 2.解题思路(一) 3.解题思路(二) 面试刷题第二天 LeetCode刷题--36.有效的数独 1.题目描述 请你判 ...

最新文章

  1. 聊一聊如何优雅地向程序员提问题
  2. java中判断字符串是否为数字的三种方法
  3. 京东小程序上线,剑指何方?
  4. 【转】OpenMP 入门教程
  5. matlab2012生成dll,64位win7下vc2010如何調用matlab2012a中生成的dll文件
  6. SalesOrder Text determination
  7. 限时秒杀┃月销10000+件,风靡全国的steam科学实验套装
  8. JavaFX UI控件教程(十五)之Combo Box
  9. websocket 获取连接id_Swoole学习笔记七:搭建WebSocket长连接 之 使用 USER_ID 作为身份凭证...
  10. 洛谷 [P2859] 摊位预定
  11. 数据库建模——用PowerDesigner对现有的数据库进行逆向工程
  12. SAStruts中文文档
  13. 2016,我有些明白了
  14. RGB颜色透明度转换
  15. 谷歌网页加载特别慢的问题
  16. 思科模拟器(Cisco Packet Tracer7.2.1)安装过程
  17. 父进程退出后,子进程自动消亡
  18. 怎么用计算机要微信,电脑端要实现“微信双开”功能,三种方法,简单实用!...
  19. lpp降维算法matlab,dimension-reduct method 多种降维算法,包括lle,lpp,ltsa matlab 238万源代码下载- www.pudn.com...
  20. 刚入门的自媒体人,也能给视频配上好听的声音

热门文章

  1. 死亡结束生命,却不会结束一段关系
  2. Android Bluetooth蓝牙开发:发现Bluetooth蓝牙设备(1)
  3. 字符串翻译python_字符串的这个东西-翻译表
  4. halcon已知多点拟合圆_5.2 halcon实现图像圆的拟合与提取
  5. Cortex-M3微处理器
  6. linux中安装卸载命令,Linux软件安装与卸载命令
  7. JSP文件验证登陆饭否网!
  8. 软件开发委托(个人)协议
  9. ORB-SLAM2 ORBmatcher.cc读代码一
  10. 记一次蚂蚁金服的面试经历