Algoritm/BOJ

[BOJ] 2667번:단지번호 붙이기

twoDeveloper 2021. 8. 5. 00:42

■ 문제풀이

1) dfs 알고리즘

 

해답

n = int(input())

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

def dfs(x, y):
  global count
  if x <= -1 or x >= n or y <= -1 or y >= n:
    return False
  if graph[x][y] == 1:
    count += 1
    graph[x][y] = 0
    dfs(x - 1, y)
    dfs(x + 1, y)
    dfs(x, y - 1)
    dfs(x, y + 1)
    return True
  return False

result = 0
danji = []
count = 0
for i in range(n):
  for j in range(n):
    if dfs(i, j) == True:
      result += 1
      danji.append(count)
      count = 0

print(result)
danji.sort()
for i in danji:
  print(i)

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

 

2667번: 단지번호붙이기

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

www.acmicpc.net

 

'Algoritm > BOJ' 카테고리의 다른 글

[BOJ] 1697번:숨바꼭질  (0) 2021.08.16
[BOJ] 2178번:미로 탐색  (0) 2021.08.13
[BOJ] 1012:유기농 배추  (0) 2021.08.09
[BOJ] 2606번:바이러스  (0) 2021.08.02
[BOJ] 1260번:DFS와 BFS  (0) 2021.08.01