文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python篇——数据结构与算法(第六部分:哈希表)

2023-09-10 19:19

关注

 

目录

1、直接寻址表

2、直接寻址表缺点

3、哈希

4、哈希表

5、解决哈希冲突

6、拉链法

7、常见哈希函数

8、哈希表的实现

8.1迭代器iter()和__iter__

8.2str()和repr()

8.3代码实现哈希表

8.4哈希表的应用


 

 8.1迭代器iter()和__iter__

def iter_test():    i = iter('happy')#!!!    try:        while True:            print i.next()    except StopIteration:        pass    s = {'one':1,'two':2,'three':3}    print s    m = iter(s) #!!!    try:        while True:            print m.next()  #s[m.next()]    except StopIteration:        passif __name__ == '__main__':        iter_test()
happy{'three': 3, 'two': 2, 'one': 1}threetwoone
class Fib(object):    def __init__(self):        self.a, self.b = 0, 1 # 初始化两个计数器a,b    def __iter__(self):        return self # 实例本身就是迭代对象,故返回自己    def next(self):        self.a, self.b = self.b, self.a + self.b # 计算下一个值        if self.a > 10: # 退出循环的条件            raise StopIteration();        return self.a # 返回下一个值if __name__ == '__main__':        for n in Fib():        print n 
112358

8.2str()和repr()

import datetimes = 'hello'd = datetime.datetime.now()print(str(s))print(repr(s))print(str(d))print(repr(d))
hello'hello'2023-6-13 22:39:18.014587datetime.datetime(2023, 6, 13, 22, 39, 18, 14587)

 Note:

def square(x) :            # 计算平方数...     return x ** 2...>>> map(square, [1,2,3,4,5])   # 计算列表各个元素的平方[1, 4, 9, 16, 25]>>> map(lambda x: x ** 2, [1, 2, 3, 4, 5])  # 使用 lambda 匿名函数[1, 4, 9, 16, 25]

8.3、代码实现哈希表

# hashclass Linklist:    class Node:        def __init__(self, item=None):            self.item = item            self.next = None    class LinkListIterator:        def __init__(self, node):            self.node = node        def __next__(self):            if self.node:                cur_node = self.node                self.node = cur_node.next                return cur_node.item            else:                raise StopIteration        def __iter__(self):            return self    def __init__(self, iterable=None):        self.head = None        self.tail = None        if iterable:            self.extend(iterable)    def append(self, obj):        s = Linklist.Node(obj)        if not self.head:            self.head = s            self.tail = s        else:            self.tail.next = s            self.tail = s    def extend(self, iterable):        for obj in iterable:            self.append(obj)    def find(self, obj):        for n in self:            if n == obj:                return True        else:            return False    def __iter__(self):        return self.LinkListIterator(self.head)    def __repr__(self):        return "<<" + ",".join(map(str, self)) + ">>"# 类似于集合的结构class HashTable:    def __init__(self, size=101):        self.size = size        self.T = [Linklist() for i in range(self.size)]    def h(self, k):        return k % self.size    def insert(self, k):        i = self.h(k)        if self.find(k):            print("Douplicated insert")        else:            self.T[i].append(k)    def find(self, k):        i = self.h(k)        return self.T[i].find(k)lk = Linklist([1, 2, 3, 4])print(lk)ht = HashTable()ht.insert(0)ht.insert(1)# hashclass Linklist:    class Node:        def __init__(self, item=None):            self.item = item            self.next = None    class LinkListIterator:        def __init__(self, node):            self.node = node        def __next__(self):            if self.node:                cur_node = self.node                self.node = cur_node.next                return cur_node.item            else:                raise StopIteration        def __iter__(self):            return self    def __init__(self, iterable=None):        self.head = None        self.tail = None        if iterable:            self.extend(iterable)    def append(self, obj):        s = Linklist.Node(obj)        if not self.head:            self.head = s            self.tail = s        else:            self.tail.next = s            self.tail = s    def extend(self, iterable):        for obj in iterable:            self.append(obj)    def find(self, obj):        for n in self:            if n == obj:                return True        else:            return False    def __iter__(self):        return self.LinkListIterator(self.head)    def __repr__(self):        return "<<" + ",".join(map(str, self)) + ">>"# 类似于集合的结构class HashTable:    def __init__(self, size=101):        self.size = size        self.T = [Linklist() for i in range(self.size)]    def h(self, k):        return k % self.size    def insert(self, k):        i = self.h(k)        if self.find(k):            print("Douplicated insert")        else:            self.T[i].append(k)    def find(self, k):        i = self.h(k)        return self.T[i].find(k)lk = Linklist([1, 2, 3, 4])print(lk)ht = HashTable()ht.insert(0)ht.insert(1)ht.insert(3)ht.insert(102)print(",".join(map(str, ht.T)))

结果

<<1,2,3,4>><<1,2,3,4>><<0>>,<<1,102>>,<<>>,<<3>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>,<<>>Process finished with exit code 0

8.4、哈希表的应用

 MD5算法

 

 

 

 

来源地址:https://blog.csdn.net/qq_42120059/article/details/131188575

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯