티스토리 뷰
[주제]
- 보간 탐색의 개념
[정의]
- 이진 탐색의 비효율성을 개선시킨 알고리즘
[중요]
- 효율적인 탐색을 위해서는 '어떻게 찾을까'가 아닌, 효율적인 탐색을 위한 '저장방법'이 무엇인지를 우선 고민해야 함
- 탐색 대상이 앞쪽에 위치해 있으면 앞쪽에서 탐색을 시작
※ 예) 고길동이라는 사람의 전화번호를 찾을 때, 전화번호부의 인덱스를 보고 'ㄱ'에 해당하는 앞쪽에서 찾기
■ 그림(보간 탐색)
- 보간 탐색은 찾아야 하는 값이 상대적으로 앞에 위치한다고 판단하면 앞쪽에 탐색
- low: 탐색 대상의 '시작' 인덱스 값
- high: 탐색 대상의 '끝' 인덱스 값
- S: 찾는 데이터가 저장된 위치의 인덱스 값
- 보간 탐색은 데이터의 값과 그 데이터가 저장된 위치의 인덱스 값이 비례한다고 가정
■ 1차 공식
A : Q = (high - low) : (S - low)
■ 2차 공식
■ 3차 공식
- 찾는 데이터의 값 'arr[S]를 x'라 할 때 최종 공식
- 오차율을 최소화하기 위해 정수형 나눗셈이 아닌 실수형 나눗셈으로 진행
'자료구조' 카테고리의 다른 글
[ch 12] AVL 트리 (4) | 2016.06.05 |
---|---|
[ch 11-2] 이진 탐색 트리 (1) | 2016.06.01 |
[ch 10-2] 복잡하지만 효율적인 정렬 알고리즘_3(기수 정렬) (0) | 2016.05.29 |
[ch 10-2] 복잡하지만 효율적인 정렬 알고리즘_2(퀵 정렬) (0) | 2016.05.18 |
[ch 10-2] 복잡하지만 효율적인 정렬 알고리즘_1(병합 정렬) (0) | 2016.05.15 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 영어
- Delphi
- 독해
- SysUtils
- 왕초보 영어회화 100일의 기적
- 알고리즘
- 일기
- 설명
- 대상
- System
- wfd
- 문법
- 자료구조
- 응용
- 스택
- tdataset
- 교육센터
- Pte
- RA
- 말하기
- 계산기
- ADODB
- Reference
- 여행영어 100일의 기적
- VCL
- 정렬
- 상황
- java
- 작문
- SWT
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함