[SWEA][D3][#05178] 노드의 합

작성:    

업데이트:

카테고리:

태그: , ,

출처

학습용 포스트입니다. 본 포스트가 문제가 될 시 수정 또는 삭제하겠습니다.


문제

완전 이진 트리의 리프 노드에 1000이하의 자연수가 저장되어 있고, 리프 노드를 제외한 노드에는 자식 노드에 저장된 값의 합이 들어있다고 한다.

다음은 리프 노드에 저장된 1, 2, 3이 주어졌을 때, 나머지 노드에 자식 노드의 합을 저장한 예이다.

그림 생략

리프 노드 저장 값 자식 노드의 합을 저장한 상태

N개의 노드를 갖는 완전 이진 트리의 노드 번호는 루트가 1번이 되며, 같은 단계에서는 왼쪽에서 오른쪽으로 증가, 단계가 꽉 차면 다음단계의 왼쪽부터 시작된다.

완전 이진 트리의 특성상 1번부터 N번까지 빠지는 노드 번호는 없다.

리프 노드의 번호와 저장된 값이 주어지면 나머지 노드에 자식 노드 값의 합을 저장한 다음, 지정한 노드 번호에 저장된 값을 출력하는 프로그램을 작성 하시오.


입력

첫 줄에 테스트케이스의 수 T가 주어진다. 1<=T<=50

다음 줄부터 테스트 케이스의 별로 노드의 개수 N과 리프 노드의 개수 M, 값을 출력할 노드 번호 L이 주어지고, 다음 줄부터 M개의 줄에 걸쳐 리프 노드 번호와 1000이하의 자연수가 주어진다.


출력

각 줄마다 “#T” (T는 테스트 케이스 번호)를 출력한 뒤, 답을 출력한다.


예제

입력

3
5 3 2
4 1
5 2
3 3
10 5 2
8 42
9 468
10 335
6 501
7 170
17 9 4
16 479
17 359
9 963
10 465
11 706
12 146
13 282
14 828
15 962


출력

#1 3
#2 845
#3 1801


My Sol

def postorder(n):
    global V
    if H[n]:
        return H[n]

    a = postorder(n*2) if n*2 <= V else H[n]
    b = postorder(n*2+1) if n*2+1 <= V else H[n]
    return a + b

# 입력 처리
T = int(input())
for tc in range(1, T+1):
    V, M, L = map(int, input().split())
    H = [0]*(V+1)

    # 리프 노드 채우기
    for _ in range(M):
        n, val = map(int, input().split())
        H[n] = val

    # L부터 트리 생성
    print(f'#{tc} {postorder(L)}')

노드의 개수보다 1 많은 0으로 구성된 H 배열을 만들고, 노드의 번호를 인덱스로 하여 입력 값을 값으로 지정하였다. 특정 노드부터 하위에 있는 모든 노드들의 값의 합을 재귀를 이용하여 더하며 반환하였다.


결과

PASS

댓글남기기