【问题标题】:Reverse link direction of singly linked list单链表的反向链接方向
【发布时间】:2016-02-17 21:08:44
【问题描述】:

我有一个反向链接的链表,有没有办法可以在这个程序中改变链接的方向?我尝试从第一个元素开始使用self.head.set_next,但是类型None 没有方法set_next,所以我不确定我将如何进行。

class Node2(object):
    def __init__(self, data=None, next_node=None):
        self.data = data
        self.next_node = next_node

    def set_next(self, new_next):
        self.next_node = new_next

    def get_data(self):
        return self.data

    def get_next(self):
        return self.next_node

class LinkedList2(object):
    def __init__(self, head=None):
        self.head = head

    def insert(self, data):
        new_node = Node(data)
        new_node.set_next(self.head)
        self.head = new_node

【问题讨论】:

    标签: python algorithm linked-list


    【解决方案1】:

    这样就可以解决问题

    # linked_list is the list you want to reverse
    previous_node = None
    current_node = linked_list.head
    
    while current_node is not None:
        next_node = current_node.get_next()
        current_node.set_next(previous_node)
        previous_node, current_node = current_node, next_node
    
    linked_list.head = previous_node
    

    这将在线性时间内执行。

    但是,如果您发现需要频繁反向链表,您可能会发现doubly linked lists 更适合您的需求

    【讨论】:

    • 创建前向链表只有两种方法吗? 1)通过反转反向链表,或 2)使用双向链表?或者有没有办法从一开始就创建一个正向链表?
    • 我不确定您所说的“从一开始”是什么意思。就像从迭代器创建链表一样?
    • @123 有没有办法从一开始就创建一个正向链表 是吗?你建立了一个正向链表......“正向”列表和“反向”列表之间的唯一区别是你的思维方式
    【解决方案2】:

    你也可以递归地做:

    prev_node = 
    cur_node = linked_list.head
    
    def reverse_ll(prev, cur):
        if not cur: return prev
        next_node = cur.get_next()
        cur.set_next(prev)
        return reverse_ll(cur, next_node)
    
    reversed_head = reverse_ll(None, cur_node)
    

    【讨论】:

      猜你喜欢
      • 2016-08-29
      • 1970-01-01
      • 2012-04-08
      • 2011-05-03
      • 1970-01-01
      • 1970-01-01
      • 2014-05-01
      • 1970-01-01
      相关资源
      最近更新 更多