티스토리 뷰

알고리즘

백준 11725 - 파이썬

취뽀가자!! 2023. 6. 13. 20:23

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

 

11725번: 트리의 부모 찾기

루트 없는 트리가 주어진다. 이때, 트리의 루트를 1이라고 정했을 때, 각 노드의 부모를 구하는 프로그램을 작성하시오.

www.acmicpc.net

문제 풀이

처음에는 예제 출력을 보고 어떻게 출력한거지 싶어 이해하는데 시간이 좀 걸렸다. 이 문제가 원하는 것은 각 노드의 부모 노드라는 것을 알았고, 입력된 노드들을 양방향으로 연결해 줬다. 그 후 부모 노드를 저장할 리스트와 방문 리스트를 별도로 선언한 후 탐색을 진행하였다.

 

import sys
from collections import deque

input = sys.stdin.readline

n = int(input())

graph = [[] for _ in range(n+1)]
ans = [0 for _ in range(n+1)]

for _ in range(n-1):
  a,b = map(int, input().split())
  graph[a].append(b)
  graph[b].append(a)

def bfs():
  q = deque()
  q.append(1)
  while q:
    v = q.popleft()
    for i in graph[v]:
      if ans[i] == 0:
        ans[i] = v
        q.append(i)


bfs()

print(graph)
print(ans)

for i in ans[2:]:
  print(i)

여기서 중요한 점은 큐에 입력되고 나간 순서대로 출력하는 것이 아닌 각 노드의 번호를 부모 노드를 저장할 리스트이 인덱스로 사용한 것이다. 또한 2번 노드부터 출력해주기 위해 슬라이싱을 사용했다.

'알고리즘' 카테고리의 다른 글

백준 2644 - 파이썬  (0) 2023.06.16
백준 2583 - 파이썬  (0) 2023.06.15
백준 2468 - 파이썬  (0) 2023.06.11
백준 4963 - 파이썬  (0) 2023.06.10
백준 16236 - 파이썬  (2) 2023.06.08
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/04   »
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30
글 보관함