Python数据结构与算法分析:实现单向链表

2,844次阅读
没有评论

共计 1803 个字符,预计需要花费 5 分钟才能阅读完成。

学习如何在 Python 中实现单向链表。探索使用 Python 代码示例的数据结构和算法分析基础知识。

Python 实现单向链表详细教程

在计算机科学中,单向链表是一种基本的数据结构,用于存储元素集合。每个节点包含一个数据元素和指向下一个节点的引用(链接)。让我们深入了解如何使用 Python 实现单向链表。

示例代码

class Node:
    def __init__(self, elem):
        """
        初始化具有元素值和下一个节点引用的节点。:param elem: 节点的元素值
        """
        self.elem = elem
        self.next = None

class SingleLinkList:
    """单向链表由节点组成,每个节点包含一个元素和指向下一个节点的链接。"""
    
    def __init__(self, node=None):
        self.__head = node
        
    def is_empty(self):
        """检查链表是否为空"""
        return self.__head is None

    def length(self):
        """返回链表的长度"""
        cur = self.__head
        count = 0
        while cur is not None:
            count += 1
            cur = cur.next
        return count

    def travel(self):
        """遍历链表"""
        cur = self.__head
        while cur is not None:
            print(cur.elem, end=' ')
            cur = cur.next

    def add(self, item):
        """在链表开头添加元素(头部插入)"""
        node = Node(item)
        node.next = self.__head
        self.__head = node

    def append(self, item):
        """在链表末尾添加元素(尾部插入)"""
        node = Node(item)
        if self.is_empty():
            self.__head = node
        else:
            cur = self.__head
            while cur.next is not None:
                cur = cur.next
            cur.next = node

    def insert(self, pos, item):
        """在特定位置插入元素"""
        if pos  (self.length() - 1):
            self.append(item)
        else:
            pre = self.__head
            count = 0
            while count 


文章来源地址 https://www.toymoban.com/diary/python/722.html

到此这篇关于 Python 数据结构与算法分析:实现单向链表的文章就介绍到这了, 更多相关内容可以在右上角搜索或继续浏览下面的相关文章,希望大家以后多多支持 TOY 模板网!

原文地址:https://www.toymoban.com/diary/python/722.html

如若转载,请注明出处:如若内容造成侵权 / 违法违规 / 事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于1970-01-01发表,共计1803字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)