我有一个反向链接的链表,有没有办法在这个程序中改变链接的方向?我尝试从第一个元素开始使用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
答案 0 :(得分:3)
这样的事情可以解决问题
# 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 :(得分:0)
您也可以递归地执行此操作:
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)