-
Notifications
You must be signed in to change notification settings - Fork 0
/
36.有效的数独.js
62 lines (56 loc) · 1.63 KB
/
36.有效的数独.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/**
* @param {character[][]} board
* @return {boolean}
*/
var isValidSudoku = function (board) {
let col = new Array(9).fill(0),
row = new Array(9).fill(0),
area = new Array(9).fill(0);
for (let i = 0; i < 9; i++) {
for (let j = 0; j < 9; j++) {
const c = board[i][j];
if (c === ".") {
continue;
}
let m = (i / 3) | 0;
let n = (j / 3) | 0;
const o = m * 3 + n;
if (
((col[i] >> c) & 1) == 1 ||
((row[j] >> c) & 1) == 1 ||
((area[o] >> c) & 1) == 1
)
return false;
col[i] |= 1 << c;
row[j] |= 1 << c;
area[o] |= 1 << c;
}
}
return true;
};
console.log(
isValidSudoku([
["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"],
])
);
console.log(
isValidSudoku([
[".", ".", "4", ".", ".", ".", "6", "3", "."],
[".", ".", ".", ".", ".", ".", ".", ".", "."],
["5", ".", ".", ".", ".", ".", ".", "9", "."],
[".", ".", ".", "5", "6", ".", ".", ".", "."],
["4", ".", "3", ".", ".", ".", ".", ".", "1"],
[".", ".", ".", "7", ".", ".", ".", ".", "."],
[".", ".", ".", "5", ".", ".", ".", ".", "."],
[".", ".", ".", ".", ".", ".", ".", ".", "."],
[".", ".", ".", ".", ".", ".", ".", ".", "."],
])
);