这篇文章主要为大家展示了“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双端链表的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://www.py.cn/jishu/jichu/33193.html