python双端链表的示例分析

发布时间:2021-09-12 19:17:33 作者:小新
来源:亿速云 阅读:122

这篇文章主要为大家展示了“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双端链表的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. Redis中的双端链表的数据结构与操作
  2. Python中反射的示例分析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

python

上一篇:python如何创建链表

下一篇:python中Label有什么用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》