티스토리 뷰
Programming/알고리즘
[응용편] Link/Cut Tree에 경로 합, 경로 최댓값 추가하기 – Augmented LCT 구현
octo54 2025. 6. 17. 17:18반응형
[응용편] Link/Cut Tree에 경로 합, 경로 최댓값 추가하기 – Augmented LCT 구현
앞선 글에서는 Link/Cut Tree(LCT)의 **핵심 구조와 기본 연산(link, cut, access)**을 Python으로 직접 구현해보았습니다.
이번에는 한 단계 더 나아가서,
LCT 노드에 값을 부여하고 경로의 합이나 최댓값을 빠르게 계산할 수 있는 구조로 확장해보겠습니다.
✨ 목표: 경로 질의가 가능한 LCT
기본 LCT는 access(u), make_root(u), link(u, v) 등을 수행할 수는 있지만,
실제로는 경로 상의 합/최댓값/최솟값을 빠르게 계산해야 할 일이 많습니다.
예: "u부터 v까지 간선 가중치의 합은?", "가장 큰 값은?"
이 기능을 위해 우리는 LCT 노드에 다음 정보를 추가합니다:
class Node:
def __init__(self, id, value=0):
self.id = id
self.left = None
self.right = None
self.parent = None
self.reversed = False
# Augmented 정보
self.value = value # 자기 자신의 값
self.sum = value # 서브트리 전체의 합
self.max_val = value # 서브트리 최대값
🔁 보조 연산 추가
📌 1. update(x): 현재 노드의 합/최댓값 갱신
def update(x):
x.sum = x.value
x.max_val = x.value
if x.left:
x.sum += x.left.sum
x.max_val = max(x.max_val, x.left.max_val)
if x.right:
x.sum += x.right.sum
x.max_val = max(x.max_val, x.right.max_val)
📌 2. push(x): 뒤집기 (Lazy Propagation)
def push(x):
if x.reversed:
x.left, x.right = x.right, x.left
if x.left:
x.left.reversed ^= True
if x.right:
x.right.reversed ^= True
x.reversed = False
🧠 Splay 연산에 보조 연산 통합
🔄 splay(x)에 push()와 update() 추가:
반응형
def splay(x):
stack = []
y = x
while not is_root(y):
stack.append(y)
y = y.parent
stack.append(y)
while stack:
push(stack.pop())
while not is_root(x):
p = x.parent
g = p.parent
if not is_root(p):
if (p.left == x) == (g.left == p):
rotate(p)
else:
rotate(x)
rotate(x)
update(x)
✅ 경로 질의 사용법
이제 다음과 같이 make_root(u), access(v)를 한 뒤 v.sum 또는 v.max_val로
u-v 경로의 합 또는 최댓값을 바로 확인할 수 있습니다.
def path_sum(u, v):
make_root(u)
access(v)
return v.sum
def path_max(u, v):
make_root(u)
access(v)
return v.max_val
🔧 테스트 예시
nodes = [Node(i, value=i) for i in range(5)]
link(nodes[0], nodes[1])
link(nodes[1], nodes[2])
link(nodes[2], nodes[3])
print(path_sum(nodes[0], nodes[3])) # 0 + 1 + 2 + 3 = 6
print(path_max(nodes[0], nodes[3])) # max(0,1,2,3) = 3
📘 다음 목표
- 경로 업데이트 (예: u-v 경로에 +5 추가)
- Lazy Propagation 확장
- 동적 MST 유지 문제 적용 예제 풀이
이제 LCT는 정적인 HLD나 ETT로는 처리할 수 없는
실시간 연결 변화, 경로 단위 최적화, 가중치 롤백 등에 적합한 자료구조가 됩니다.
LinkCutTree응용, 트리경로합, LCT확장버전, pathSum, pathMax, 동적트리업데이트, SplayTreeAugment, 파이썬알고리즘, 알고리즘트리강의, SEO 최적화 10개
'Programming > 알고리즘' 카테고리의 다른 글
[마무리편] 세그먼트 트리부터 Link/Cut Tree까지: 트리 알고리즘 시리즈 정리와 추천 학습 루트 (0) | 2025.06.23 |
---|---|
Link/Cut Tree 실전 적용: 동적 MST(Minimum Spanning Tree) 유지 전략 (0) | 2025.06.20 |
Python으로 Link/Cut Tree 직접 구현하기 (기초 버전) (0) | 2025.06.16 |
[고급편] Link/Cut Tree 완전 정복: 동적 트리 쿼리와 간선 연결/삭제 처리 기법 (0) | 2025.06.13 |
실전 문제 풀이: 트리 쿼리 알고리즘 완전 적용하기 (ETT & HLD & LCA) (0) | 2025.06.11 |
※ 이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다.
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- SEO 최적화
- Ktor
- nodejs
- Python
- gatsbyjs
- seo 최적화 10개
- nextJS
- PostgreSQL
- 개발블로그
- AI챗봇
- llm
- 프론트엔드
- 백엔드개발
- CI/CD
- REACT
- JAX
- fastapi
- rag
- NestJS
- SEO최적화
- Prisma
- Next.js
- 웹개발
- Docker
- flax
- kotlin
- 파이썬알고리즘
- 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 | 31 |
글 보관함
반응형