CS/자료구조

[자료구조] 이진탐색트리

안드선생 2023. 2. 16. 11:16
반응형

1. 이진탐색트리란?

이진탐색트리란 이진탐색(Binary Search)연결리스트(Linked List)를 결합한 자료구조의 일종이다.

 

  이진 탐색 연결 리스트
장점 탐색에 소요되는 시간복잡도가 O(logN) 로 빠르다 삽입과 삭제에 걸리는 시간 복잡도가 O(1)로 빠르다
단점 삽입과 삭제가 불가능하다 탐색의 시간 복잡도가 O(N) 이다

 

위와 같은 이진 탐색과 연결리스트의 장점을 고안하기 위해 만들어졌으며, 

이진 탐색의 효율적인 탐색 능력을 유지하면서도

빈번한 자료 입력과 삭제가 가능하기 위해 사용된다.

 


2. 이진탐색트리 특징

 

 

이진탐색트리는 이진트리의 일종으로 다음과 같은 규칙으로 구성한다.

  • 모든 노드는 유일한 키를 갖음. (중복된 노드 X)
  • 각 노드의 왼쪽 서브 트리에는 해당 노드의 값보다 작은 값을 지닌 노드들로 이루어짐.
  • 각 노드의 오른쪽 서브 트리에는 해당 노드의 값보다 큰 값을 지닌 노드들로 이루어짐.
  • 각 노드의 왼쪽, 오른쪽 서브트리 또한 이진탐색트리로 구성.

 

다음은 이진탐색트리가 가진 특징이다.

탐색의 시간 복잡도는 트리의 높이를 h라고 할 때 O(h) 이다.


위와 같은 편향 트리의 경우 탐색에 O(N)의 시간이 소요된다.

 

  • 이진탐색 트리의 순회는 중위 순회 (in order) 방식이다. (왼쪽 - 루트 - 오른쪽)


    중위 순회: 4, 7, 16, 20, 37, 38, 43 (중위 순회 방식으로 정렬된 순서를 얻을 수 있다)

 

  • 이진탐색트리의 삽입 연산은 루트노드에서 탐색을 시작해 서브트리가 없는 리프 노드에서 이루어진다.

이진탐색트리의 삭제 연산은 세가지 케이스로 나누어 연산한다.

  • 자식 노드가 없는 경우 -> 삭제할 노드를 그냥 없앤다.
  • 자식 노드가 하나 있는 경우 -> 삭제할 노드의 자식을 올린다.
  • 자식 노드가 두 개 있는 경우 -> 오른쪽 서브 트리에서 가장 작은 값 or 왼쪽 서브 트리에서 가장 큰 값을 올린다.
Q: 자식 노드가 두 개인 경우 오른쪽 서브트리와 왼쪽 서브트리 중 어느 것을 선택해야 하나요?

A: 오른쪽 서브트리와 왼쪽 서브트리를 정하는 규칙은 따로 정해져있지 않으며 두 방식에 차이가 있지 않습니다.
따라서 구현자가 두 방식 중에 자유롭게 선택해 규칙을 정할 수 있습니다.

 

 

3. 시간복잡도

Q: 이진탐색트리의 시간복잡도는?

A. 트리의 높이를 h라고 할 때 O(h)이다.
노드의 개수 N이 주어졌을 때 균등 트리 일 경우, O(logN) 이며
편향 트리일 경우 최악의 경우, O(N) 이다.
Q. 이진탐색트리의 삽입,삭제 연산 시간복잡도는?

A. 이진탐색트리의 삽입과 삭제 연산은 탐색이후 이루어지기 때문에
탐색에 필요한 O(h)이 소요되며 연결리스트를 사용하므로
입력과 삭제에는 O(1)이 사용된다.


따라서 총 소요되는 시간 복잡도는 O(h)이며
최악의 경우 탐색과 동일하게 O(N)이 소요된다.

※ 따라서, 이진 탐색 트리는 한쪽 방향으로 노드가 집중된 편향트리에서는 효율적이지 않다.

반응형

'CS > 자료구조' 카테고리의 다른 글

[자료구조] 레드 블랙 트리  (0) 2023.02.16
[자료구조] B-Tree & B+Tree  (0) 2023.02.16
[자료구조] 힙(Heap) 에 대하여  (0) 2023.02.16
[자료구조] 스택(Stack), 큐(Queue)  (0) 2023.02.15
[자료구조] 트리(Tree)  (0) 2023.02.15