感谢您的阅读,您的关注点赞就是对我最大的支持,谢谢!
官方交流裙:606115027
一种更复杂的链表是“双向链表”或“双面链表”。每个节点有两个链接:一个指向前一个节点,当此节点为第一个节点时,指向空值;而另一个指向下一个节点,当此节点为最后一个节点时,指向空值。
指定位置插入节点
def insert(self, pos, item): """在指定位置添加节点""" if pos <= 0: self.add(item) elif pos > (self.length()-1): self.append(item) else: node = Node(item) cur = self.__head count = 0 # 移动到指定位置的前一个位置 while count < (pos-1): count += 1 cur = cur.next # 将node的prev指向cur node.prev = cur # 将node的next指向cur的下一个节点 node.next = cur.next # 将cur的下一个节点的prev指向node cur.next.prev = node # 将cur的next指向node cur.next = node删除元素
def remove(self, item): """删除元素""" cur = self.__head while cur != None: # 找到了要删除的元素 if cur.item == item: # 先判断此结点是否是头节点 # 头节点 if cur == self.__head: self.__head = cur.next # 如果存在下一个结点,则设置下一个结点 if cur.next: # 判断链表是否只有一个结点 cur.next.prev = None else: cur.prev.next = cur.next # 如果存在下一个结点,则设置下一个结点 if cur.next: cur.next.prev = cur.prev break else: cur = cur.next测试
if __name__ == "__main__": ll = DLinkList() ll.add(1) ll.add(2) ll.append(3) ll.insert(2, 4) ll.insert(4, 5) ll.insert(0, 6) print "length:",ll.length() ll.travel() print ll.search(3) print ll.search(4) ll.remove(1) print "length:",ll.length() ll.travel() 学Python的安娴 数据分析 Python 解答小可爱 感谢各位大佬们的关注,有问题可私我免费解答,需要学习视频、文档、源码的可以看以下获取方式哔哩哔哩账号:学Python的安娴官方学习口口裙:11418-60209