22856 트리 순회 Python

Derhon·2023년 12월 4일
0

22856 트리 순회

failed

import sys
sys.setrecursionlimit(10 ** 6)
n = int(sys.stdin.readline().rstrip())
tree = [[] for _ in range(n + 1)]
cnt = 0
ans = 0
finish = 0

for i in range(n):
    root, left, right = list(map(int, sys.stdin.readline().rstrip().split()))
    if left == -1: left = 0
    if right == -1: right = 0
    tree[root].append(left)
    tree[root].append(right)

def max_right(node):
    global finish
    if tree[node][0]: max_right(tree[node][0])
    finish = node
    if tree[node][1]: max_right(tree[node][1])

def inorder(node):
    global cnt
    global ans
    if node == finish:
        ans = cnt
    if tree[node][0]:
        cnt += 1
        inorder(tree[node][0])
        cnt += 1
        if node == finish:
            ans = cnt
    if tree[node][1]:
        cnt += 1
        inorder(tree[node][1])
        cnt += 1

max_right(1)
inorder(1)
print(ans)

거의 1시간동안 풀었지만 실패...
중위 순회에 대한 기초 지식이 별로 없었던 것 같다.
오늘은 트리 공부해야겠다.

profile
🧑‍🚀 이사했어요 ⮕ https://99uulog.tistory.com/

0개의 댓글