使用递归显示链表中所有节点的Python程序

使用递归显示链表中所有节点的Python程序

当需要使用递归方法显示链表中的元素/节点时,需要一种向链表添加值的方法和一种打印链表元素的方法。还将具有使用递归的helper方法,即再次调用帮助函数以打印值。

下面是一个演示:

更多Python相关文章,请阅读:Python 教程

示例

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

class my_linked_list:
    def __init__(self):
        self.head = None
        self.last_node = None

    def add_value(self, my_data):
        if self.last_node is None:
            self.head = Node(my_data)
            self.last_node = self.head
        else:
            self.last_node.next = Node(my_data)
            self.last_node = self.last_node.next

    def print_it(self):
        self.helper_print(self.head)

    def helper_print(self, curr):
        if curr is None:
            return

        print(curr.data)
        self.helper_print(curr.next)

my_instance = my_linked_list()
n = int(input('How many elements you wish to add ? '))
for i in range(n):
    data = int(input('Enter a data item : '))
    my_instance.add_value(data)

print('该链表: ')
my_instance.print_it()

输出

你想添加多少个元素?4
输入一个数据项:34
输入一个数据项:67
输入一个数据项:12
输入一个数据项:89
链表:
34
67
12
89

解释

  • 创建’Node’类。

  • 创建另一个具有所需属性的’my_linked_list’类。

  • 它有一个’init’函数,用于将第一个元素初始化为’None’,即’head’,并将最后一个节点初始化为’None’。

  • 定义了另一种名为’add_value’的方法,用于将数据添加到链表中。

  • 定义另一种名为’print_it’的方法,它调用helper方法在控制台上显示链表数据。

  • 定义了另一种名为’helper_print’的方法,用于在控制台上显示链表数据。

  • 定义这个helper函数,因为这里需要使用递归。

  • 创建’my_linked_list’类的对象。

  • 接受用户输入,确定链表中元素的数量。

  • 对此范围进行迭代,并调用方法添加数据。

  • 使用’print_it’方法在控制台上显示这一点。

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程