오늘도 더 나은 코드를 작성하였습니까?

B Tree 데이터 삭제 본문

자료구조

B Tree 데이터 삭제

hik14 2023. 10. 11. 19:27

* 나무위키의 내용 및

*아래 링크의 유튜브 영상을 보고  본 글은 제 학습의 결과를 정리한 내용입니다.

https://www.youtube.com/watch?v=H_u28u0usjA 

 

데이터 삭제

1. 모든 데이터는 leaf-node에서 삭제를 진행한다.

- internal node를 삭제해야 된다면,

lower_bound (삭제 해야되는 노드 보다 작은 값 중 가장 큰것)

upper_bound (삭제 해야되는 노드 보다 큰 값 중 가장 작은 것) 

 

* 항상 lower_bound / upper_bound는 B tree 특성상 항상 leaf 노드에 존재한다.  

둘 중에 1개를 골라 internal node와 위치를 바꾼뒤 삭제를 진행한다면, B tree의 key 정렬 조건을 위배하지 않는다.

 

 

15를 삭제 하려고 한다면,

9 - lower_bound (삭제 해야되는 노드 보다 작은 값 중 가장 큰것) 또는,

20 - upper_bound (삭제 해야되는 노드 보다 큰 값 중 가장 작은 것) 과 값을 변경하여 삭제 진행한다.

 

2. 불만족한 상황 발생시

데이터 삭제 이후 최소 n차 B tree가 가져야하는 최소의 key의 개수 보다 적은 노드가 발생한 경우.

* 최소의 key 수 =  ceil(n/2) - 1

1) 형제 노드에서 불만족한 노드 기준 왼쪽 형제부터 데이터를 가져와서 해결함.

2) 형제 노드만으로 해결이 안된다면,

부모 노드로 각 포인터의 중간값 데이터를 가져오고, 왼쪽으로 노드 병합 및 정렬 이후 불필요한 노드 삭제.

- 위 절차를 시행시 부모 노드가 불만족이 발생하였다면, 동일한 절차를 반복함 

 

예시) 5차 B tree에서 데이터 삭제.

최소의 key 개수  =  2

 90 delete - leaf 노드에 90은 존재하기 때문에, 삭제후 오름차순 정렬

75 delete

internal 노드를 lower_bound와 교체.

삭제이후 불만족 발생으로 인한 재조정.

오른쪽 형제노드에서 데이터를 정렬순대로 빌려옴.

45 delete

internal 노드를 lower_bound와 교체

삭제이 불만족이 발생하였고, 형제노드에서 데이터를 가져올수도 없는 상황이라, 부모로 부터 중간값을 내려받고, 

두노드를 왼쪽으로 병합한다.

부모노드에서 불만족이 발생. 

형제노드에서 데이터를 가져올수도 없는 상황이라, 부모로 부터 중간값을 내려받고, 두 노드를 왼쪽으로 병합한다.

불필요한 노드 삭제.

60 delete

internal 노드를 lower_bound와 교체후 삭제.

불만족 발생하였으나, 형제로부터 key를 빌려 올수 있음, 빌리고 데이터를 오름 차순으로 정렬