일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- DP 알고리즘
- CSS
- N과 M
- 백준 1487번
- BTREE
- 백준
- 해싱
- html
- 0의 개수
- 1
- 풍선터뜨리기
- 해설
- 실버
- 문제 풀이
- 백준 1246번
- 백준 11050번
- 백준 14501번
- hashing
- 알고리즘
- B-tree
- Python
- 가치규범의 공공외교
- 이항계수
- 1141번
- 한반도평화와공공외교
- 연산자 문제
- 주창형 공공외교
- 풀이
- 파이썬
- 챗봇
- Today
- Total
SunFly의 코딩 및 정보 블로그
이진 탐색 트리(Binary Search Tree)란? 본문
■ 탐색을 효육적으로 하기 위한 자료구조
※ 특징
- 이진트리이며 모든 원소는 서로 다른 유일한 키(key)를 가진다.
- (왼쪽 sub-트리의 key값) < (루트의 key값) < (오른쪽 sub-트리의 key값)
- 왼쪽 sub-트리와 오른쪽 sub-트리도 이진탐색트리이다.
※ 탐색 : searchBST()연산
- ROOT에서 시작.
- 탐색할 key값을 루트 노드의 key값과 비교.
- (1) (키값 = 루트 노드의 키값) : 원하는 원소를 찾았으므로 탐색 성공.
- (2) (키값 < 루트 노드의 키값) : 루트 노드의 왼쪽 sub-트리에 대해서 탐색연산 수행.
- (3) (키값 > 루트 노드의 키값) : 루트 노드의 오른쪽 sub-트리에 대해서 탐색연산 수행.
▷예시 코드
BinTree* searchBST(BunTree* bt, BTData x)
{
BinTree* p = bt;
while(p != NULL) {
if(x == p->key) return p;
if(x < p->key) p = p->left;
else p = p->right;
}
printf("Error: 찾는 키가 없습니다.\n");
retrun NULL;
}
※ 삽입 : insertBST() 연산
- 먼저 탐색 연산을 수행
- 탐색 실패한 위치에 원소를 삽입
▷예시 코드
void insertBST(BinTree* bt, BTData x) {
BinTree* p = bt;
BinTree* parent = NULL;
//삽입할 노드 탐색
while(p != NULL) {
if(x == p->key) {
printf("Error: 이미 같은 키가 있습니다.\n");
return;
}
parent = p;
if(x < p->key) p = p->left;
else p = p->right;
}
//삽입할 노드 생성
BinTree* newNode = (BinTree*)malloc(sizeof(BinTree));
newNode->key = x;
newNode->left = NULL;
newNode->right = NULL;
//삽입노드 연결
if(bt == NULL) bt = newNode;
if(x < parent->key) parent->left = newNode;
else parent->right = newNode;
}
※ 삭제 : deleteBST() 연산
- Case 1: 삭제할 노드의 차수가 0인 경우
- 부모의 해당 자식의 필드를 NULL로 처리후 노드 삭제
- Case 2: 삭제할 노드의 차수가 1일 경우
- 삭제될 노드의 자식을 삭제될 노드의 부모노드에 연결후 노드 삭제
- Case 3: 삭제할 노드의 차수가 2인 경우
- 1. 삭제할 노드의 자손들 중 후계자를 선택하여 자리를 물려줌
- 2. 후계자: 왼쪽 sub-트리 중 가장 큰 원소 or 오른쪽 sub-트리 중 가장 작은 원소
- 3. 후계자 노드는 자식이 1 또는 0이므로 CASE1, CASE2 이용
'알고리즘' 카테고리의 다른 글
B+Tree 삽입(Insertion) 알고리즘 - 1 (0) | 2021.10.12 |
---|---|
B+Tree 알고리즘이란? (0) | 2021.10.11 |
B-tree 구현 (C언어 구현) (0) | 2021.10.11 |
B-tree 삭제(Deletion) 알고리즘 (Redistribution/Merge 알고리즘) (0) | 2021.10.11 |
B-tree 탐색(searching or Retrieval) 알고리즘 (0) | 2021.10.11 |