반응형
새로운 것은 즐겁다. Go를 통해 알고리즘을 풀어보자.
문제 링크
package main
import (
"bufio"
"fmt"
"os"
"strconv"
)
var H, W int
var dx = [4]int{-1, 0, 1, 0}
var dy = [4]int{0, -1, 0, 1}
var visited = [100][100]bool{}
var touch = [100][100]int{}
var board = [100][100]int{}
var cheeseCnt int
func initializing() {
for i := 0; i < H; i++ {
for j := 0; j < W; j++ {
visited[i][j] = false
touch[i][j] = 0
}
}
}
func dfs(row, col int) {
visited[row][col] = true
nowRow := row
nowCol := col
for k := 0; k < 4; k++ {
nextRow := nowRow + dy[k]
nextCol := nowCol + dx[k]
if nextCol >= 0 && nextCol < W && nextRow >= 0 && nextRow < H {
if board[nextRow][nextCol] == 0 { //빈 칸일때
if !visited[nextRow][nextCol] {
dfs(nextRow, nextCol)
}
} else { //치즈일때
touch[nextRow][nextCol]++
if touch[nextRow][nextCol] >= 2 {
cheeseCnt--
board[nextRow][nextCol] = 0
visited[nextRow][nextCol] = true
if cheeseCnt == 0 {
return
}
}
}
}
}
}
func main() {
fmt.Scan(&H, &W)
answer := 0
scanner := bufio.NewScanner(os.Stdin)
scanner.Split(bufio.ScanWords)
for h := 0; h < H; h++ {
for w := 0; w < W; w++ {
scanner.Scan()
board[h][w], _ = strconv.Atoi(scanner.Text())
if board[h][w] == 1 {
cheeseCnt++
}
}
}
for true {
dfs(0, 0)
answer++
initializing()
if cheeseCnt == 0 {
break
}
}
fmt.Print(answer)
}
반응형
'Study > Algorithm' 카테고리의 다른 글
[Algorithm]BOJ_20056_마법사 상어와 파이어볼_Go (0) | 2021.08.23 |
---|---|
[Algorithm]BOJ_14500_테트로미노_Go (0) | 2021.08.12 |
[Algorithm]BOJ_16234_인구이동_Go (0) | 2021.08.11 |
[Algorithm]BOJ_2407_조합_Go (0) | 2021.08.04 |
[Algorithm] BOJ_9251_LCS - JAVA (0) | 2021.07.20 |