티스토리 뷰
Programming/알고리즘
Treap 기반 Euler Tour Tree 구현: 동적 연결성 및 서브트리 쿼리를 동시에 처리하는 고급 자료구조
octo54 2025. 5. 27. 11:02반응형
Treap 기반 Euler Tour Tree 구현: 동적 연결성 및 서브트리 쿼리를 동시에 처리하는 고급 자료구조
이번 글에서는 Treap 기반 Euler Tour Tree (ETT) 구현법을 소개합니다.
앞서 Segment Tree로 구현한 ETT는 서브트리 쿼리에는 적합하지만,
간선 삽입/삭제가 많은 Fully Dynamic Connectivity 문제에는 제한이 있습니다.
**Treap(트립)**은 **Binary Search Tree(BST)**와 Heap의 특성을 결합한 자료구조로,
삽입/삭제/스플릿/머지 연산이 모두 **O(log N)**에 가능하며
ETT를 구현하는 데 최적화된 도구입니다.
✅ 목표
기능 지원 여부 시간복잡도
link(u, v) | ✅ | O(log N) |
cut(u, v) | ✅ | O(log N) |
connected(u, v) | ✅ | O(log N) |
subtree_query(u) | ✅ | O(log N) |
update_node(u, val) | ✅ | O(log N) |
🔧 Treap + ETT 구조 설계
- 노드 진입/이탈 시점을 Treap의 노드로 관리
- 오일러 투어 순서가 Treap의 중위순회 순서가 되도록 구성
- Treap의 각 노드는:
- key: 오일러 투어 순서
- priority: 무작위 힙값
- val: 해당 노드의 값 (ex. 서브트리 크기 1, 가중치 등)
- sum: 하위 트리 전체 값 누적 (Lazy 지원 가능)
🛠 Python 구현: Treap 기반 ETT (핵심만)
반응형
1. Treap 노드 정의
import random
class TreapNode:
def __init__(self, key, value):
self.key = key # Euler Tour order
self.value = value
self.sum = value
self.size = 1
self.priority = random.randint(1, 1 << 30)
self.left = None
self.right = None
2. Treap 유틸 함수
def update(node):
if node:
node.size = 1
node.sum = node.value
if node.left:
node.size += node.left.size
node.sum += node.left.sum
if node.right:
node.size += node.right.size
node.sum += node.right.sum
def split(node, key):
if not node:
return (None, None)
if key < node.key:
left, right = split(node.left, key)
node.left = right
update(node)
return (left, node)
else:
left, right = split(node.right, key)
node.right = left
update(node)
return (node, right)
def merge(left, right):
if not left or not right:
return left or right
if left.priority > right.priority:
left.right = merge(left.right, right)
update(left)
return left
else:
right.left = merge(left, right.left)
update(right)
return right
3. ETT Wrapper 클래스
class TreapETT:
def __init__(self, n):
self.n = n
self.nodes = [TreapNode(i, 1) for i in range(n)] # 각 노드 진입
self.repr = list(range(n)) # 연결성 확인용 간단한 루트 배열
self.treaps = [self.nodes[i] for i in range(n)]
def find(self, u):
while self.repr[u] != u:
self.repr[u] = self.repr[self.repr[u]]
u = self.repr[u]
return u
def connected(self, u, v):
return self.find(u) == self.find(v)
def link(self, u, v):
if self.connected(u, v):
return False
root_u = self.find(u)
root_v = self.find(v)
t = merge(self.treaps[root_u], self.treaps[root_v])
self.repr[root_v] = root_u
self.treaps[root_u] = t
return True
def cut(self, u, v):
# 실제 구현 시: 오일러 순서 고려하여 해당 경로 split → remove
pass
def subtree_sum(self, u):
root = self.find(u)
return self.treaps[root].sum
⚠️ 이 구현은 단순 연결성 & subtree_sum용 핵심 개요이며,
실제 cut(), 오일러 순서 관리 등을 하려면 entry/exit 노드를 따로 두고,
오일러 투어를 중위순회로 맞춰야 합니다.
✅ 실전 예시
ett = TreapETT(5)
ett.link(0, 1)
ett.link(1, 2)
print("0–2 connected?", ett.connected(0, 2)) # True
print("Subtree sum (root 0):", ett.subtree_sum(0)) # 3
ett.link(3, 4)
print("3–2 connected?", ett.connected(3, 2)) # False
📘 응용 문제
문제 번호 제목 내용
Codeforces 613E | Longest Path in Tree | 경로 유지 + 동적 트리 연결 |
ARC 112D | Fully Dynamic Graph | Treap 기반 ETT 최적 적용 |
백준 13510 | 트리와 쿼리 1 | Cut/Link + 쿼리 처리 |
📌 결론 요약
- Treap 기반 ETT는 Segment Tree보다 더 유연하고 삽입/삭제에 강함
- 연결성 유지 + 서브트리 질의 + 연결/삭제 모두 O(log N)
- Competitive Programming에서는 ETT with Treap or Splay Tree가 상위 기술
👉 다음 글에서는 Splay Tree 기반 ETT 구조를 구현하며,
LCT(Link/Cut Tree)와의 차이와 통합 전략까지 설명합니다.
📚 참고자료
- [CP-Algorithms – Euler Tour Tree (Treap)]
- Sleator & Tarjan (1983) “Self-Adjusting Binary Search Trees”
- Stanford CS166: Augmented BST for dynamic connectivity
Treap, EulerTourTree, ETT, 동적트리, 연결성유지, FullyDynamicConnectivity, 서브트리쿼리, 트리최적화, 파이썬알고리즘, SEO 최적화 10개
'Programming > 알고리즘' 카테고리의 다른 글
※ 이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다.
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- fastapi
- 개발블로그
- 파이썬 알고리즘
- kotlin
- CI/CD
- rag
- NestJS
- JAX
- Webpack
- nextJS
- gatsbyjs
- 프론트엔드
- llm
- REACT
- SEO최적화
- 백엔드개발
- Docker
- AI챗봇
- Ktor
- Python
- Prisma
- 프론트엔드면접
- nodejs
- SEO 최적화
- 딥러닝
- seo 최적화 10개
- Next.js
- PostgreSQL
- App Router
- 웹개발
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함
반응형