데이터 구조 및 알고리즘: 해시 테이블
11088 단어 dsalgo
data:image/s3,"s3://crabby-images/3533d/3533d0afd735a4997c11adf6640aafd01cc28f99" alt=""
여기서 우리는 사전의 키와 값을 가져와 함수(상자 및 기어 1)에 넣을 것입니다.
예를 들어 여기에서 {"nails":1000} 사전을 사용합니다.
data:image/s3,"s3://crabby-images/86837/868377fc960aa84c09e9b0e4ac0455a0a771b6d8" alt=""
data:image/s3,"s3://crabby-images/3aa79/3aa798b3c65d5ab41e57c23e4ce5b42f9c07ab60" alt=""
data:image/s3,"s3://crabby-images/c7a03/c7a033adf125a95bf25a956c034456023e8587a9" alt=""
해시는 값 2와 키 및 값이 있는 목록을 반환했습니다.
이 2는 기본적으로 목록이 상주할 주소입니다.
data:image/s3,"s3://crabby-images/36fdc/36fdc19e4bb43c4d52e3110e56a6e80543362a43" alt=""
data:image/s3,"s3://crabby-images/1dec0/1dec08411d52565943ce4ab49fae5c5ef019ebf9" alt=""
{"나사":800}도 마찬가지입니다.
data:image/s3,"s3://crabby-images/59047/59047b3c393a4e7957aa95b688fdedb5226b6281" alt=""
data:image/s3,"s3://crabby-images/5aced/5acedfeb92c3662471c80bb38404ea4e8ffa2334" alt=""
data:image/s3,"s3://crabby-images/fae6f/fae6f05e91fe3c6aaf36c4a75626f04bb7bbdfd1" alt=""
{"nuts":1200}도 마찬가지입니다.
data:image/s3,"s3://crabby-images/9c61e/9c61e3e2b477bee28d77bb5af1bf55debbc84c0e" alt=""
data:image/s3,"s3://crabby-images/be17c/be17cf7176cf96c3131876d227646888524de24a" alt=""
data:image/s3,"s3://crabby-images/685c2/685c2661a8473fb39378b5a7fc2f52f0528d3f5e" alt=""
그건 그렇고 몇 가지 사항에 유의하십시오.
또한 충돌 문제를 해결하기 위해 해시 테이블이나 연결 목록에 배열을 넣을 수 있습니다. 따라서 우리는 여러 양의 데이터를 가질 수 있고 여전히 동일한 출력을 얻을 수 있습니다.
data:image/s3,"s3://crabby-images/0c518/0c518e9be9d81eb8ac6629002b4f6d2ab0e80896" alt=""
data:image/s3,"s3://crabby-images/c7458/c74588d48cc0a87c2341fd5eba0c2496eeee0c2a" alt=""
또는,
data:image/s3,"s3://crabby-images/0310c/0310cb05edd4fb21bca4c9f9e987b688e5292dbd" alt=""
data:image/s3,"s3://crabby-images/ba52c/ba52c5878885b4e0166cc80156d5b8070b632405" alt=""
건설자
크기 7의 data_map 배열을 유지할 클래스를 생성해 보겠습니다. [참고: 배열 크기는 고정되어 있습니다.]
data:image/s3,"s3://crabby-images/3bf58/3bf58ed9f1a68748c2b628ebdfcfaf1cadd08698" alt=""
또한 이것은 우리의 해시 방법이 될 것입니다.
data:image/s3,"s3://crabby-images/88582/885826bdafa25a3c7e012dafbd711976c91b3103" alt=""
모듈러스와 len(self.data_map)이 있는 이유는 크기가 7인 배열이 있고 7로 나눈 값이 있으면 0에서 6까지 알림을 받기 때문입니다. 따라서 키 값을 배열 내에 유지할 수 있습니다. 알았어요?
해시 테이블 코드:
class HashTable:
def __init__(self, size = 7):
self.data_map = [None] * size
def __hash(self, key):
my_hash = 0
for letter in key:
my_hash = (my_hash + ord(letter) * 23) % len(self.data_map)
return my_hash
def print_table(self):
for i, val in enumerate(self.data_map):
print(i, ": ", val)
my_hash_table = HashTable()
my_hash_table.print_table()
data:image/s3,"s3://crabby-images/79335/79335519b308bf307b25164ee5909cc437f0a281" alt=""
아직 할당된 값이 없기 때문에 이와 같은 출력을 갖게 됩니다.
테이블 내에서 키와 값을 설정하는 메서드 설정
set 메서드를 포함한 전체 코드:
class HashTable:
def __init__(self, size = 7):
self.data_map = [None] * size
def print_table(self):
for i, val in enumerate(self.data_map):
print(i, ": ", val)
def __hash(self, key):
my_hash = 0
for letter in key:
my_hash = (my_hash + ord(letter) * 23) % len(self.data_map)
return my_hash
#created the set method
def set_item(self, key, value):
index = self.__hash(key) #cheks the index of the key
if self.data_map[index] == None: #if there is no array already reated within the array, creates one array
self.data_map[index] = []
self.data_map[index].append([key, value]) #appends key and value within the array
my_hash_table = HashTable()
my_hash_table.set_item('bolts', 1400)
my_hash_table.set_item('washers', 50)
my_hash_table.set_item('lumber', 70)
my_hash_table.print_table()
data:image/s3,"s3://crabby-images/064dd/064dd5d45881d67ddcf29cc41f43a2afe80cac84" alt=""
키와 값 가져오기
get 코드용 코드
class HashTable:
def __init__(self, size = 7):
self.data_map = [None] * size
def __hash(self, key):
my_hash = 0
for letter in key:
my_hash = (my_hash + ord(letter) * 23) % len(self.data_map)
return my_hash
def print_table(self):
for i, val in enumerate(self.data_map):
print(i, ": ", val)
def set_item(self, key, value):
index = self.__hash(key)
if self.data_map[index] == None:
self.data_map[index] = []
self.data_map[index].append([key, value])
#creating the get method
def get_item(self, key):
index = self.__hash(key) #looks for the index of the key
if self.data_map[index] is not None: #if there is an array within the array, it will return the value
for i in range(len(self.data_map[index])): #loops through the array and sets value for i using the length of it
if self.data_map[index][i][0] == key: #if it founds the key, sends the value of it
return self.data_map[index][i][1]
return None #else returns none as nothing is out there
my_hash_table = HashTable()
my_hash_table.set_item('bolts', 1400)
my_hash_table.set_item('washers', 50)
#check for values using key
print(my_hash_table.get_item('bolts'))
print(my_hash_table.get_item('washers'))
print(my_hash_table.get_item('lumber'))
산출:
data:image/s3,"s3://crabby-images/7e853/7e8530aa5ef2b8a4590e1c97f68392effad031c1" alt=""
모든 키
우리가 가지고 있는 모든 키를 저장하는 방법을 만들어 봅시다.
암호:
class HashTable:
def __init__(self, size = 7):
self.data_map = [None] * size
def __hash(self, key):
my_hash = 0
for letter in key:
my_hash = (my_hash + ord(letter) * 23) % len(self.data_map)
return my_hash
def print_table(self):
for i, val in enumerate(self.data_map):
print(i, ": ", val)
def set_item(self, key, value):
index = self.__hash(key)
if self.data_map[index] == None:
self.data_map[index] = []
self.data_map[index].append([key, value])
def get_item(self, key):
index = self.__hash(key)
if self.data_map[index] is not None:
for i in range(len(self.data_map[index])):
if self.data_map[index][i][0] == key:
return self.data_map[index][i][1]
return None
#Keys method
def keys(self):
all_keys = [] #creating an array to store the keys
for i in range(len(self.data_map)): #loops through the array
if self.data_map[i] is not None: # checkes if the array is empty or there is an array within it
for j in range(len(self.data_map[i])): #loops through the inside array
all_keys.append(self.data_map[i][j][0]) #if found an array, stores the first values within the all_key array
return all_keys
my_hash_table = HashTable()
my_hash_table.set_item('bolts', 1400)
my_hash_table.set_item('washers', 50)
my_hash_table.set_item('lumber', 70)
print(my_hash_table.keys())
산출:
data:image/s3,"s3://crabby-images/a9a7a/a9a7a3aa42eeb806f60116cfe5e8d6021a249c1c" alt=""
**
인터뷰 문제를 풀어봅시다.
**
A=[2,4,5] 및 B=[0,8,5] 2개의 목록이 있다고 가정합니다.
목록/배열 내에 공통적인 것이 있는지 확인하십시오.
좋습니다. 두 가지 접근 방식을 사용할 수 있습니다.
이를 위한 코드:
def item_in_common(list1, list2):
for i in list1:
for j in list2:
if i == j:
return True
return False
list1 = [1,3,5]
list2 = [2,4,6]
print(item_in_common(list1, list2))
def item_in_common(list1, list2):
my_dict = {}
for i in list1:
my_dict[i] = True
for j in list2:
if j in my_dict:
return True
return False
list1 = [1,3,5]
list2 = [2,4,6]
print(item_in_common(list1, list2))
그래서, 우리는 해시 테이블을 어디에 사용했습니까? 우리는 여기에 필요하지 않았습니다. 그러나 사전은 해시 테이블의 간단한 버전입니다.
완료! 즐기자
data:image/s3,"s3://crabby-images/dec34/dec343edd461908800919a0dd13263113e19431b" alt=""
Reference
이 문제에 관하여(데이터 구조 및 알고리즘: 해시 테이블), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/mitul3737/data-structure-algorithms-hash-table-2893텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)