会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132358个问题
Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 31楼
Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 34楼

老师,我感觉是照着你的代码写的,但是发现运行结果不对,我觉得是find_key方法写的有问题。

class Array():
    def __init__(self,size=4):
        self.__size = size # 记录容器大小
        self.__item = [None]*size #分配空间
        self.__length = 0

    def __setitem__(self,key,value):
        self.__item[key] = value
        self.__length += 1

    def __getitem__(self,key):
        return self.__item[key]
    
    def __len__(self):
        return self.__length
    
    def __iter__(self):
        for value in self.__item:
            yield value


class Slot():
    def __init__(self,key=None,value=None):
        self.key = key
        self.value = value
    
    def __str__(self):
        return 'key:{},value:{}'.format(self.key,self.value)
    
class HashTable():
    def __init__(self,size=4):
        self.size = size
        self.item = Array(self.size)
    
    def get_index(self,key):
        return hash(key) % self.size
    
    def find_index_to_insert(self,key):
        index = self.get_index(key) # 获取key对应的索引
        if self.item[index] == None: # 索引没被占用
            return index
        else:
            while self.item[index] is not None:
                if key == self.item[index].key: # 获取到相同的key
                    return index
                else:
                    index = (index*5+1) % self.size
            return index

    def push(self,key,value): # 存放数据
        index = self.find_index_to_insert(key)  # 获取key对应的索引
        self.item[index] = Slot(key,value)

    def find_key(self,key):
        index = self.get_index(key) # 获取key对应的索引
        if self.item[index] == None:
            return None
        else:
            while self.item is not None:
                if key == self.item[index].key: # 判断查找的Key是否与item里的key相同
                    return index
                else:
                    index = (index*5+1) % self.size
            return None
    
    def get(self,key): # 获取数据
        index = self.find_key(key) # 获取key对应的索引
        if index:
            return self.item[index]
        return None
    
if __name__ == "__main__":
    h = HashTable()
    h.push('name','吕布')
    h.push('sex1','男')
    h.push('sex2','女')
    h.push('sex3','保密')

    print(h.get('name'))
    print(h.get('sex3'))
    print(h.get('sex2'))
    print(h.get('sex1'))
    # print(h.get('age'))


运行结果:

image.png

Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 35楼
Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 36楼
Python 全系列/第十六阶段:数据结构与算法/数据结构与算法 37楼
Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 38楼
Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 40楼

老师,这个知识点我没能理解,我不明白图中位置的 current 是如何放在循环里进行循环的? 他是什么原理?  我打印出来他们类型都不一样

image.png

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

    def __str__(self):
        return 'Node:{}'.format(self.value)


class DoubleLinkedList():
    def __init__(self):
        self.root = Node()
        self.size = 0
        self.end = None

    def append(self, value):
        node = Node(value)  # 封装节点对象
        # 判断是否已经有数据
        if not self.end:  # 如果没有节点
            self.root.next = node  # 将root的下一个节点 设置为新的node节点
            node.prev = self.root  # 设置新节点的上一个节点为root
        else:
            self.end.next = node  # 将原来最后节点的下一个节点 设置为新的node节点
            node.prev = self.end  # 将原来最后节点的上一个节点 设置为最后一个节点的节点
        self.end = node  # 更新最后 一个节点新加的节点
        self.size += 1

    def append_first(self, value):
        node = Node(value)
        # 判断是否已经连接数据
        if not self.end:  # 如果没有节点
            self.root.next = node  # 将root 节点的下一个节点设置为新的node节点
            node.prev = self.root  # 将新的bode节点的上一个节点 设置为root 节点
            self.end = node  # 更新最后一个新加的root节点
        else:
            temp = self.root.next  # 报讯原来的第一个节点
            node.next = temp  # 将新的node节点 的下一个节点 设置为原来的第一个的节点
            temp.prev = node  # 更新原来保存的第一个节点的上一个节点微信的node节点
        node.prev = self.root  # 将新的node节点 的上一个节点 设置为root节点
        self.root.next = node  # 将 root 节点间的下一个节点 设置为新的node节点
        self.size += 1

    def __iter__(self):
        current = 0
        print(type(current))
        print(type(self.end))
        if current:
            # print(dir(current))
            while current is not self.end:
                yield current.value
                current = current.next
                # print(current)
                print(type(current))
            yield current.value

    def revers_iter(self):
        current = self.end
        while current is not self.root:
            yield current
            current = current.prev
            print(current)
            print(dir(current))


if __name__ == "__main__":
    link = DoubleLinkedList()
    link.append('李白')
    link.append('貂蝉')
    link.append('王昭君')
    link.append('闵月')
    link.append('小乔')
    link.append_first('大乔')

    for v in link:
        print(v)
        
    print('*' * 10, '  返回节点 ', '*' * 10)
    
    for v in link.revers_iter():
        print(v)


Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 43楼

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

class LinkList():
    def __init__(self):
        self.root = Node()  # 代表头
        self.size = 0  # 代表有几个数据
        self.next = None  # 通过设置next的值为0,来记录最后一个节点是谁,方便新加数据时,安排在那个元素后面
    
    def append(self, value):
        node = Node(value)  # 实例化
        # 判断是否已经有数据
        if not self.next: # 如果没有节点时
            self.root.next = node  # 将新节点挂到root后面
            self.next = node  # 因为self.next的值是None、node的next值是None,所以相当于node代替了self.next
        else:
            self.next.next = node  # 在最后一个节点的next指向node
            self.next = node  # 因为self.next的值是None、node的next值是None,所以相当于node代替了self.next
        self.size += 1
    def append_first(self,value):
        node = Node(value)  # 实例化
        if not self.next:  # 如果没有节点时
            self.root.next = node  # 直接在root后面加节点,相当于在头部加数据
            self.next = node  # 仅有node这一个数据,所以node也是最后一个节点
        else:
            temp = self.root.next  # 获取原来root后面的那个节点
            self.root.next = node  # 将新的节点挂到root上
            node.next = temp  # 新的节点的下一个节点是原来root后面的节点
        self.size += 1
    def __iter__(self):
        """遍历 """
        current = self.root.next
        while current is not self.next:
            yield current.value
            current = current.next
        yield current.value
if __name__ == '__main__':
    link = LinkList()
    link.append('孙悟空')
    link.append('猪八戒')
    link.append_first('唐僧')

    for i in link:
        print(i)

image.png

老师,请问红线处标注的理解是否正确?尤其是红色箭头处

Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 44楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637