Python 程序仅反转链接列表的前 N 个元素
pythonserver side programmingprogramming
当需要反转链接列表中的特定元素集时,会定义一个名为"reverse_list"的方法。该方法会遍历列表,并反转特定的元素集。
下面是同样的演示 −
示例
class Node: def __init__(self, data): self.data = data self.next = None class LinkedList_structure: def __init__(self): self.head = None self.last_node = None def add_vals(self, data): if self.last_node is None: self.head = Node(data) self.last_node = self.head else: self.last_node.next = Node(data) self.last_node = self.last_node.next def print_it(self): curr = self.head while curr: print(curr.data) curr = curr.next def reverse_list(my_list, n): if n == 0: return before_val = None curr = my_list.head if curr is None: return after_val = curr.next for i in range(n): curr.next = before_val before_val = curr curr = after_val if after_val is None: break after_val = after_val.next my_list.head.next = curr my_list.head = before_val my_instance = LinkedList_structure() my_list = input('输入链接列表的元素... ').split() for elem in my_list: my_instance.add_vals(int(elem)) n = int(input('输入列表中要反转的元素数量... ')) reverse_list(my_instance, n) print('新列表为:') my_instance.print_it()
输出
输入链接列表的元素... 45 67 89 12 345 输入列表中要反转的元素数量... 3 新列表为: 89 67 45 12 345
解释
‘Node’类。
创建另一个具有所需属性的 ‘LinkedList_structure’ 类。
它有一个 ‘init’ 函数,用于初始化第一个元素,即将 ‘head’ 初始化为 ‘None’。
定义了一个名为 ‘add_vals’ 的方法,用于将值添加到堆栈。
定义了另一个名为 ‘print_it’ 的方法,用于在控制台上显示链接列表的值。
定义了另一个名为 ‘reverse_list’ 的方法,用于反转链接列表的特定元素集。
‘LinkedList_structure’ 的实例已创建。
元素已添加到链接列表中。
元素显示在控制台上。
需要反转的元素数量取自用户。
在此链接列表上调用‘reverse_list’方法。
输出显示在控制台上。