[자료구조] 05. 해쉬테이블 (Hash Table)

해쉬테이블 (Hash Table)의 정의와 특징에 대하여 알아보고 사용예시를 살펴본다.

1. 정의

키(Key)에 데이터(Value)를 저장하는 데이터 구조이다. Key를 통해 바로 데이터를 받아올 수 있으므로, 속도가 획기적으로 빠르고 파이썬 딕셔너리(Dictionary) 타입이 이에 해당한다.

2. 특징

  • 장점
    • 데이터 저장/읽기 속도가 빠르다. (검색 속도가 빠르다.)
    • 해쉬는 키에 대한 데이터가 있는지(중복) 확인이 쉬움
  • 단점
    • 일반적으로 저장공간이 좀더 많이 필요하다.
    • 여러 키에 해당하는 주소가 동일할 경우 충돌을 해결하기 위한 별도 자료구조가 필요함
  • 주요 용도
    • 검색이 많이 필요한 경우
    • 저장, 삭제, 읽기가 빈번한 경우
    • 캐쉬 구현시 (중복 확인이 쉽기 때문)

3. 시간 복잡도

O(1)


© 2020. All rights reserved.