这篇文章主要为大家展示了“python双端链表的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python双端链表的示例分析”这篇文章吧。
1、双端链表的一个结点有两个指针,分别指向前一个结点和后一个结点。
2、双端链表是指由prev(前驱指针)和next(后驱指针)组成的数据结构。
这两个是为了构建节点之间的关系。
实例
class DoubleNode:
def __init__(self,item):
self.item = item
self.next = None
self.prior = None
class HandleDouNode:
def create_node_head(self,li):
head = DoubleNode(li[0])
for element in li[1:]:
node = DoubleNode(element)
node.next = head # 新节点的指针链接到原来head结点
head.prior = node # 原来head结点的上一个指针链接到node
head = node # 头节点指向node
return head
def create_node_tail(self,li):
head = DoubleNode(li[0])
tail = head
for element in li[1:]:
node = DoubleNode(element)
tail.next = node #原来的尾部结点的下一个指针链接到node
node.prior = tail # node结点的前一个指针连接到原来尾部
tail = node # 修改尾部指针为node
return head
def print_node(self,head):
while head:
print(head.item,end=',')
head = head.next
hdn = HandleDouNode()
head = hdn.create_node_tail([1,2,3])
print(head.item)
print(head.next.item)
print(head.next.prior.item)
"""
OUT
1
2
1
"""
以上是“python双端链表的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注天达云行业资讯频道!