首页 后端开发 Python教程 如何在 Python 中实现单向链表

如何在 Python 中实现单向链表

Sep 10, 2024 am 06:46 AM

How to Implement Singly Linked List in Python

class Node:
    def __init__(self,value):
        self.value = value
        self.next = None

class LinkedList:
    def __init__(self):
        self.head = None

    def add_front(self,value):
        new_node = Node(value)
        new_node.next = self.head
        self.head = new_node
    def add_back(self,value):
        new_node = Node(value)
        if self.head is None:
            self.head = new_node
        else:
            current = self.head
            while current.next is not None:
                current = current.next
            current.next = new_node
    def print_list(self):
        current = self.head
        while current is not None:
            print(current.value)
            current = current.next

list1 = LinkedList()

list1.add_front(1)
list1.add_front(2)
list1.add_back(3)
list1.print_list()

登录后复制

1。节点类:

  • 代表链表中的单个元素。
  • 每个节点都有两个属性:value 用于存储数据,next 指向列表中的下一个节点。
  • 创建节点时,其下一个指针设置为 None。

2。链表类:

  • 管理链表操作。
  • 有一个属性头,它是链表的起点。最初,由于列表为空,所以 head 设置为 None。

3。 add_front 方法:

  • 将新节点添加到链表的前面。
  • 使用给定值创建一个新节点。
  • 新节点的下一个指针被设置为列表的当前头。
  • 列表的头部随后更新为新节点。

4。 add_back方法:

  • 将新节点添加到链表的末尾。
  • 使用给定值创建一个新节点。
  • 如果列表为空(即 head 为 None),则将新节点设置为 head。
  • 如果链表不为空,则遍历到链表末尾,然后更新最后一个节点的next指针指向新节点。

5。 print_list 方法:

  • 打印链表中从头到尾的所有值。
  • 从头部开始,使用next指针迭代每个节点,直到到达末尾(None),打印每个节点的值。

6。用法示例:

  • 创建了 LinkedList 的实例。
  • add_front 被调用两次,将值为 1 和 2 的节点添加到列表的前面。
  • 调用add_back将值为3的节点添加到列表末尾。
  • 调用print_list打印链表中所有节点的值。输出为2,1,3,说明节点添加正确。

以上是如何在 Python 中实现单向链表的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
两个点博物馆:所有展览以及在哪里可以找到它们
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
两个点博物馆:所有展览以及在哪里可以找到它们
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

我如何使用美丽的汤来解析HTML? 我如何使用美丽的汤来解析HTML? Mar 10, 2025 pm 06:54 PM

我如何使用美丽的汤来解析HTML?

python中的图像过滤 python中的图像过滤 Mar 03, 2025 am 09:44 AM

python中的图像过滤

如何在Python中下载文件 如何在Python中下载文件 Mar 01, 2025 am 10:03 AM

如何在Python中下载文件

如何使用Python查找文本文件的ZIPF分布 如何使用Python查找文本文件的ZIPF分布 Mar 05, 2025 am 09:58 AM

如何使用Python查找文本文件的ZIPF分布

如何使用Python使用PDF文档 如何使用Python使用PDF文档 Mar 02, 2025 am 09:54 AM

如何使用Python使用PDF文档

如何在django应用程序中使用redis缓存 如何在django应用程序中使用redis缓存 Mar 02, 2025 am 10:10 AM

如何在django应用程序中使用redis缓存

如何使用TensorFlow或Pytorch进行深度学习? 如何使用TensorFlow或Pytorch进行深度学习? Mar 10, 2025 pm 06:52 PM

如何使用TensorFlow或Pytorch进行深度学习?

如何在Python中实现自己的数据结构 如何在Python中实现自己的数据结构 Mar 03, 2025 am 09:28 AM

如何在Python中实现自己的数据结构

See all articles