반응형




이진 탐색 트리의 경우 한 쪽으로 노드들이 쏠릴 수 있다.





이러한 불균형 트리구조 때문에 균형 잡는 방법을 생각하다가 만들어 진 것이 Red-Black Tree이다.


< Red-Black Tree의 조건>


1. root는 항상 블랙이어야 한다.

2. 블랙 밑에 블랙은 가능, 블랙 밑에 레드도 가능, 레드 밑에 블랙도 가능하다.


3. root는 블랙일 때, root 부터 leaf까지 경로가 있는데 내가 지나가는 블랙 노드의 개수는 항상 똑같아야 한다.

즉, root->leaf까지 가는 블랙 노드의 개수는 항상 같다.




(결국 이 말에서 유추할 수 있는 것은 제일 짧은 경로는 블랙으로만 이루어 진다는 것이고,

제일 긴 경로는 레드와 블랙으로 섞여있다. 하지만, root에서 leaf로 가는동안 블랙을 만나는 개수는 항상 같다.)





< Red-Black Tree의 특성>


1. 부모 노드가 black, 자식 노드 두개가 red인 경우 부모 노드는 red, 자식 노드가 black으로 바꿀 수 있다. (반대로도 가능하다.)

 

아래 그림은 상향 색변환이고,  반대로 할 시, 하향 색변환이라고 한다.





2. 다음과 같이 구성된 4가지 트리는 오른쪽과 같이 변형될 수 있다. 




반응형