반응형
백준 2667번 단지번호붙이기
파이썬 풀이
import sys
input = sys.stdin.readline
N = int(input())
graph = [list(input().rstrip()) for i in range(N)] # 그래프 생성
visited = [[0] * N for i in range(N)] # 방문 정점
houses = []
house = 0
def search(i, j): # 탐색
global house
# 종료 조건
if i < 0 or j >= N or i >= N or j < 0 or graph[i][j] == '0':
return
graph[i][j] = '0' # 탐색한 지점 0으로 변경
visited[i][j] = 1 # 방문한 정점 표시
house += 1 # 마을 수 갱신
# 동서남북 탐색
search(i + 1, j)
search(i, j + 1)
search(i - 1, j)
search(i, j - 1)
for i in range(N):
for j in range(N):
if visited[i][j] == 0 and graph[i][j] == '1':
search(i,j)
houses.append(house)
house = 0
print(len(houses))
for i in sorted(houses):
print(i)
반응형
'Python > 백준' 카테고리의 다른 글
[백준 파이썬] 7576번 토마토 (0) | 2021.05.05 |
---|---|
[백준 파이썬] 1687번 숨바꼭질 (0) | 2021.05.04 |
[백준 파이썬] 2178번 미로 탐색 (0) | 2021.05.03 |
[백준 파이썬] 2512번 예산 (0) | 2021.05.02 |
[백준 파이썬] 2805번 나무 자르기 (0) | 2021.05.02 |