哈希表


 

import pprint


class HashTable:
    '''拉链法解决哈希冲突'''
    def __init__(self, elements):
        self.bucket_size = len(elements)
        self.buckets = [[] for _ in range(self.bucket_size)]
        self._assign_buckets(elements)

    def _assign_buckets(self, elements):
        for key, value in elements:
            hashed_key = hash(key)
            index = hashed_key % self.bucket_size
            self.buckets[index].append((key, value))

    def get_value(self, input_key):
        hashed_key = hash(input_key)
        index = hashed_key % self.bucket_size
        for key, vlaue in self.buckets[index]:
            if key == input_key:
                return vlaue
        return None

    def __str__(self):
        return pprint.pformat(self.buckets)


if __name__ == '__main__':
    capitals = [
        ('France', 'Paris'),
        ('United States', 'Washington D.C.'),
        ('Italy', 'Rome'),
        ('Canada', 'Ottawa')
    ]
    hashtable = HashTable(capitals)
    print(hashtable)
    print(f"The capital of Italy is {hashtable.get_value('Italy')}")
    '''
    pprint result
    [[('Canada', 'Ottawa')],
    [('France', 'Paris')],
    [('United States', 'Washington D.C.'), ('Italy', 'Rome')],
    []]
    The capital of Italy is Rome
    '''

 

import pprint


class HashTable:
    '''
    开放寻址法:线性探测
    缺点:开放式寻址策略的主要问题是,如果您还必须处理表中元素的删除,则需要执行逻辑删除而不是物理删除,因为如果您删除在冲突期间占用存储桶的值,则另一个碰撞的元素将永远不会被发现。
    在我们之前的示例中,它Italy与先前插入的元素(France)相撞,因此已被重新定位到下一个存储桶,因此删除该France元素将使其Italy无法访问,因为它不占用其自然的目标存储桶,对于解释器而言这是空的。
    因此,在使用开放式寻址策略时,要删除一个元素,您必须用一个哑数值替换其存储桶,这向解释器表明,必须考虑删除该元素以进行新的插入,但必须将其占用以进行检索。
    '''

    def __init__(self, elements):
        self.bucket_size = len(elements)
        self.buckets = [None] * self.bucket_size
        self._assign_buckets(elements)

    def _assign_buckets(self, elements):
        for key, value in elements:
            hashed_key = hash(key)
            index = hashed_key % self.bucket_size

            while self.buckets[index] is not None:
                print(f"The key {key} collided with {self.buckets[index]}")
                ###线性探测###
                index = (index + 1) % self.bucket_size

            self.buckets[index] = (key, value)

    def get_value(self, input_key):
        hashed_key = hash(input_key)
        index = hashed_key % self.bucket_size
        while self.buckets[index] is not None:
            key, value = self.buckets[index]
            if key == input_key:
                return value
            index = (index + 1) % self.bucket_size

    def __str__(self):
        return pprint.pformat(self.buckets)


if __name__ == '__main__':
    capitals = [
        ('France', 'Paris'),
        ('United States', 'Washington D.C.'),
        ('Italy', 'Rome'),
        ('Canada', 'Ottawa')
    ]
    hashtable = HashTable(capitals)
    print(hashtable)
    print(f"The capital of Italy is {hashtable.get_value('Italy')}")
    '''
The key United States collided with ('France', 'Paris')
[('Italy', 'Rome'),
 ('France', 'Paris'),
 ('United States', 'Washington D.C.'),
 ('Canada', 'Ottawa')]
The capital of Italy is Rome
    '''

 

posted @ 2020-10-17 10:32  烧刘病  阅读(98)  评论(0编辑  收藏  举报
回到页首