알고리즘 정복하기!/백준 문제풀이

백준 2667번 Python / DFS

by seokii 2022. 1. 25.
728x90
반응형

깊이 우선 탐색(DFS)이란?

https://seokii.tistory.com/30

 

[알고리즘] 깊이 우선 탐색 (DFS, Depth-First Search)이란?

깊이 우선 탐색(DFS, Depth-First Search) - 그래프 탐색에서 루트 노드에서 시작해 다음 분기로 넘어가기 전에 해당 분기를 완벽하게 탐색하는 방법 - 재귀 혹은 스택 자료구조를 이용함 장점 - 현 경로

seokii.tistory.com

깊이 우선 탐색 알고리즘 개념에 대한 내용입니다.

 

문제 링크

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

 

2667번: 단지번호붙이기

<그림 1>과 같이 정사각형 모양의 지도가 있다. 1은 집이 있는 곳을, 0은 집이 없는 곳을 나타낸다. 철수는 이 지도를 가지고 연결된 집의 모임인 단지를 정의하고, 단지에 번호를 붙이려 한다. 여

www.acmicpc.net

 

풀이

n = int(input())
graph = []
num = []
for _ in range(n):
    graph.append(list(map(int, input())))

dx = [-1, 1, 0, 0]
dy = [0, 0, -1, 1]
cnt = 0

def dfs(x, y):
    if x < 0 or x >= n or y < 0 or y >= n:
        return False

    if graph[x][y] == 1:
        global cnt
        cnt += 1
        graph[x][y] = 0
        for i in range(4):
            nx = dfs(x+dx[i], y+dy[i])
        return True

for i in range(n):
    for j in range(n):
        if dfs(i, j) == True:
            num.append(cnt)
            cnt = 0

print(len(num))
num.sort()
for i in num:
    print(i)
728x90
반응형

댓글