Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- 이분탐색
- Spring
- 스택
- 시뮬레이션
- 조합
- SWEA
- 투 포인터
- 프로그래머스
- 백준
- 2021 KAKAO BLIND RECRUITMENT
- 비트마스킹
- 우선순위큐
- 플로이드 와샬
- 백트래킹
- 다익스트라
- 투포인터
- GIT
- 크루스칼
- 플로이드와샬
- 2019 KAKAO BLIND RECRUITMENT
- 파이썬
- 브루트포스
- 최소 신장 트리
- 로봇 청소기
- BFS
- 2020 카카오 인턴십
- 2018 KAKAO BLIND RECRUITMENT
- 트라이
- 구현
- 2020 KAKAO BLIND RECRUITMENT
Archives
- Today
- Total
개발조아
[BOJ/백준] 9934 완전 이진 트리 파이썬 본문
728x90
문제 링크 : https://www.acmicpc.net/problem/9934
이진트리의 중위순회을 이용하여 풀었다.
중위 탐색은 왼쪽 자식노드 먼저 탐색하고 자신 노드 보고 오른쪽 자식 노드를 보는 순회 방식이다.
전위,중위,후위 순회 방식을 문제의 그림을 보고 설명하면 아래와 같다.
더보기
사진 링크 : https://www.acmicpc.net/problem/9934
전위 순회는 자신 노드를 먼저 확인하고 왼쪽 자식 노드를 탐색하고 오른쪽 자식 노드를 탐색하는 방식이다.
그림의 트리로 탐색한다면
3 6 1 4 2 5 7 순서로 탐색한다.
중위 순회는 왼쪽 자식 노드를 탐색하고 자신 노드를 확인 후 오른쪽 노드를 탐색하는 방식이다.
그림의 트리로 탐색한다면
1 6 4 3 5 2 7 순서로 탐색한다.
후위 순회는 왼쪽 자식 노드를 탐색하고 오른쪽 자식 노드를 탐색한 후 자신 노드를 확인하는 방식이다.
그림의 트리로 탐색한다면
1 4 6 5 7 2 3 순서로 탐색한다.
문제의 입력으로 주어진 상근이가 방문한 순서는 이진트리를 중위순회로 탐색한 것으로
자신 노드를 확인할 때 노드의 번호를 순서대로 저장한 것이다.
따라서 직접 중위순회로 탐색 하면서 자신 노드를 확인할 때 해당 깊이에 입력받은 번호를 차례대로 넣으면 된다.
from sys import stdin
input = stdin.readline
n = int(input())
nums = list(map(int, input().split()))
num_idx = 0
tree = [[] for _ in range(n)]
def solv():
inorder(0)
for row in tree:
print(*row)
def inorder(depth):
global tree,num_idx
if depth == n:
return
inorder(depth+1)
tree[depth].append(nums[num_idx])
num_idx += 1
inorder(depth+1)
solv()
'알고리즘 > 백준' 카테고리의 다른 글
[BOJ/백준] 16985 Maaaaaaaaaze 파이썬 (0) | 2021.08.19 |
---|---|
[BOJ/백준] 2116 주사위 쌓기 파이썬 (0) | 2021.08.19 |
[BOJ/백준] 12904 A와 B 파이썬 (0) | 2021.08.18 |
[BOJ/백준] 13459 구슬 탈출 파이썬 (0) | 2021.08.18 |
[BOJ/백준] 백준 1022 소용돌이 예쁘게 출력하기 파이썬 (0) | 2021.08.15 |
Comments