[자료구조] 05. 해쉬테이블 (Hash Table)
1. 정의
키(Key)에 데이터(Value)를 저장하는 데이터 구조이다. Key를 통해 바로 데이터를 받아올 수 있으므로, 속도가 획기적으로 빠르고 파이썬 딕셔너리(Dictionary) 타입이 이에 해당한다.
2. 특징
- 장점
- 데이터 저장/읽기 속도가 빠르다. (검색 속도가 빠르다.)
- 해쉬는 키에 대한 데이터가 있는지(중복) 확인이 쉬움
- 단점
- 일반적으로 저장공간이 좀더 많이 필요하다.
- 여러 키에 해당하는 주소가 동일할 경우 충돌을 해결하기 위한 별도 자료구조가 필요함
- 주요 용도
- 검색이 많이 필요한 경우
- 저장, 삭제, 읽기가 빈번한 경우
- 캐쉬 구현시 (중복 확인이 쉽기 때문)
3. 시간 복잡도
O(1)