해시 테이블에 대해서 알아보겠습니다. 핸드폰 전화번호부를 만든다고 생각해볼게요. 이렇게 쭉 데이터를 쌓아보겠습니다. 자료구조는 데이터를 효율적으로 정렬하고 찾기 위해서 사용하겠죠? 그래서, 한큐에 찾기 위해 Hash Table이라는 애를 만들었습니다. Insert와 Delete의 시간복잡도는 O(1)입니다. 최악의 경우 O(n)일 수도 있습니다. (충돌이 났을 때) 아래와 같은 그림처럼 충돌이 일어나면 어떻게 해야 하는가? 이럴 때는, 데이터를 옆에 붙여버리거나, 빈 공간에 할당해줄 수 있습니다. 이 것은 Chaining, Open Addressing 이라고 합니다. 자, 그러면 hash table을 구현해보겠습니다. # Hash table만들기 hash_table = [[] for _ in range(..