Skip to content

Commit b4e77f1

Browse files
committed
add: leetcode 0794 solution
1 parent a3c7d42 commit b4e77f1

File tree

1 file changed

+40
-0
lines changed

1 file changed

+40
-0
lines changed
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
package leetcode
2+
3+
func validTicTacToe(board []string) bool {
4+
cntX, cntO := 0, 0
5+
for i := range board {
6+
for j := range board[i] {
7+
if board[i][j] == 'X' {
8+
cntX++
9+
} else if board[i][j] == 'O' {
10+
cntO++
11+
}
12+
}
13+
}
14+
if cntX < cntO || cntX > cntO+1 {
15+
return false
16+
}
17+
if cntX == cntO {
18+
return process(board, 'X')
19+
}
20+
return process(board, 'O')
21+
}
22+
23+
func process(board []string, c byte) bool {
24+
//某一行是"ccc"
25+
if board[0] == string([]byte{c, c, c}) || board[1] == string([]byte{c, c, c}) || board[2] == string([]byte{c, c, c}) {
26+
return false
27+
}
28+
//某一列是"ccc"
29+
if (board[0][0] == c && board[1][0] == c && board[2][0] == c) ||
30+
(board[0][1] == c && board[1][1] == c && board[2][1] == c) ||
31+
(board[0][2] == c && board[1][2] == c && board[2][2] == c) {
32+
return false
33+
}
34+
//某一对角线是"ccc"
35+
if (board[0][0] == c && board[1][1] == c && board[2][2] == c) ||
36+
(board[0][2] == c && board[1][1] == c && board[2][0] == c) {
37+
return false
38+
}
39+
return true
40+
}

0 commit comments

Comments
 (0)