BOJ 1012 - 유기농 배추

folder_open Algorithm / BOJ / silver | date_range

sell #BOJ #1012 #silver #python #파이썬 #코딩테스트 #알고리즘

문제 링크

https://www.acmicpc.net/problem/1012

잡담

오 건강에 좋을 듯

구현

DFS 혹은 BFS를 이용하는 문제다. 어떤 것을 사용해도 상관없다. 나는 DFS를 이용해서 구현했는데, 한 번 재귀에 들어갈 때만 count를 올려주면 된다.

코드

from sys import stdin, setrecursionlimit
setrecursionlimit(10 ** 9)
input = lambda : stdin.readline()

visited = set()
def recur(x, y, farm, info) -> None:
    global visited
    visited.add((x, y))
    for i, j in zip([-1, 0, 1, 0], [0, -1, 0, 1]):
        new_x, new_y = x + i, y + j
        if 0 <= new_x < info[0] and 0 <= new_y < info[1]:
            if (new_x, new_y) not in visited and farm[new_y][new_x]:
                recur(new_x, new_y, farm, info)

def dfs(m, n, farm) -> int:
    global visited
    visited = set()
    count = 0
    for y in range(n):
        for x in range(m):
            if (x, y) not in visited and farm[y][x]:
                count += 1
                recur(x, y, farm, (m, n))
    return count

def solution() -> None:
    t = int(input())
    for _ in range(t):
        m, n, k = map(int, input().split())
        farm = [[0 for col in range(m)] for row in range(n)]
        for __ in range(k):
            x, y = map(int, input().split())
            farm[y][x] = 1
        print(dfs(m, n, farm))
        
if __name__ == '__main__':
    solution()