单向链表的反向链接方向



我有一个反向链接的链表,有没有办法改变这个程序中链接的方向?我尝试从第一个元素开始使用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

这样的东西就可以了

# 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

这将以线性时间执行。

但是,如果您发现需要经常反向链表,您可能会发现双向链表更适合您的需求

您也可以递归地执行此操作:

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)

相关内容

  • 没有找到相关文章

最新更新