Назначение / извлечение методов, не работающих в отдельной цепочке хэш-карт Python

1

Хотя я знаю, что у Python есть встроенный словарь для практических целей, я пытаюсь понять концепцию отдельных хеш-карт цепочки, создавая один с цветами и их определениями.

Когда я пытаюсь распечатать извлечение с хэш-карты, я получаю None.

from linked_list import Node, LinkedList

class HashMap:
  def __init__(self, size):
    self.array_size = size
    self.array = [LinkedList() for i in range(size)]

  def hash(self, key):
    return sum(key.encode())

  def compress(self, hash_code):
    return hash_code % self.array_size

  def assign(self, key, value):
    hash_code = self.hash(key)
    array_index = self.compress(hash_code)
    payload = Node([key, value])
    list_at_array = self.array[array_index]
    for item in list_at_array:
      if key == item[0]:
        item[1] = value
      else:
        self.array[array_index].insert(payload)

  def retrieve(self, key):
    hash_code = self.hash(key)
    array_index = self.compress(hash_code)
    list_at_index = self.array[array_index]
    for item in list_at_index:
      if item[0] == key:
        return item[1]
      else:
        return None

from blossom_lib import flower_definitions

blossom = HashMap(len(flower_definitions))

for each in flower_definitions:
  blossom.assign(each[0], each[1])
print(blossom.retrieve('daisy'))

Вот два модуля:

blossom_lib.py

flower_definitions = [['begonia', 'cautiousness'], ['chrysanthemum', 'cheerfulness'], ['carnation', 'memories'], ['daisy', 'innocence'], ['hyacinth', 'playfulness'], ['lavender', 'devotion'], ['magnolia', 'dignity'], ['morning glory', 'unrequited love'], ['periwinkle', 'new friendship'], ['poppy', 'rest'], ['rose', 'love'], ['snapdragon', 'grace'], ['sunflower', 'longevity'], ['wisteria', 'good luck']]

linked_list.py

class Node:
  def __init__(self, value):
    self.value = value

  def get_value(self):
    return self.value

  def get_next_node(self):
    return self.next_node

  def set_next_node(self, next_node):
    self.next_node = next_node

class LinkedList:
  def __init__(self, head_node=None):
    self.head_node = head_node

  def insert(self, new_node):
    current_node = self.head_node

    if not current_node:
      self.head_node = new_node

    while(current_node):
      next_node = current_node.get_next_node()
      if not next_node:
        current_node.set_next_node(new_node)

  def __iter__(self):
    current_node = self.head_node
    while(current_node):
      yield current_node.get_value()

Заранее спасибо!

Теги:
hashmap

1 ответ

0

Здесь есть несколько проблем.

1) Инициализация Node next_node - результат AttributeError

def __init__(self, value):
    self.value = value
    self.next_node = None

2) LinkedList - переменная current_node управляющая циклом, никогда не перемещалась в следующий элемент в списке.

def __iter__(self):
    current_node = self.head_node
    while (current_node):
        value = current_node.get_value()
        current_node = current_node.get_next_node()
        yield value

3) insert LinkedList - аналогично предыдущему случаю, current_node никогда не перемещался в следующий элемент в списке.

while (current_node):
    next_node = current_node.get_next_node()
    if not next_node:
        current_node.set_next_node(new_node)
    current_node = next_node

4) HashMap assign - это усложненная, после определения правильного списка, чтобы поместить его в, достаточно использовать insert методы этого списка.

def assign(self, key, value):
    hash_code = self.hash(key)
    array_index = self.compress(hash_code)
    payload = Node([key, value])
    list_at_array = self.array[array_index]
    list_at_array.insert(payload)

5) HashMap retrieve - он вернет None, если в списке было несколько элементов (с одинаковым значением хэша), и первый элемент не был тем, который мы искали. Правильный подход заключается в том, чтобы возвращать None после итерации по всем элементам в списке, а если элемент не найден, возвращается None, поэтому исправление должно уменьшать отступ return None.

def retrieve(self, key):
    hash_code = self.hash(key)
    array_index = self.compress(hash_code)
    list_at_index = self.array[array_index]
    for item in list_at_index:
        if item[0] == key:
            return item[1]
    return None

Проверка правильности для вашего примера:

for each in flower_definitions:
    print(each[0] + ' (' + str(sum(each[0].encode()) % len(flower_definitions)) + '): ' + blossom.retrieve(each[0]))

дает:

begonia (11): cautiousness
chrysanthemum (2): cheerfulness
carnation (7): memories
daisy (6): innocence
hyacinth (2): playfulness
lavender (9): devotion
magnolia (0): dignity
morning glory (7): unrequited love
periwinkle (4): new friendship
poppy (8): rest
rose (7): love
snapdragon (5): grace
sunflower (3): longevity
wisteria (4): good luck

Полное решение можно найти здесь

Ещё вопросы

Сообщество Overcoder
Наверх
Меню