单链表

时间:2016-02-17 21:08:45

标签: python algorithm linked-list

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

2 个答案:

答案 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)