使用递归反转链接列表

时间:2018-06-02 10:45:50

标签: c++ recursion linked-list reverse

我希望能够编写一个递归函数来反转链表。想象一下,所有元素都已经附加到列表中了。

我想在head旁边分配head-> next->所以node-> next的下一个节点就是节点本身。然后,当递归完成时,将链表的头部(this-> head)分配给最终节点(即头部)。

还缺少的是将最后一个节点分配给NULL。

在任何世界都会有这样的作品吗?它给出了运行时/分段错误。

struct node {
    int data;
    node *next;
};

class LinkedList{
    node *head = nullptr;
public:
    node *reverse(node *head){
        if(head->next != nullptr){
            reverse(head->next)->next = head;
        }
        else{
            this->head = head;
        }
        return head;
    }
};

2 个答案:

答案 0 :(得分:2)

请注意,您忽略了头部nullptr本身的情况。此外,您无法返回head ...您需要返回反向列表的头部。

试试这个:

node* reverse_list(node* head) {
    if (head == nullptr or head->next == nullptr) { return head; }
    auto tail = head->next;
    auto reversed_tail = reverse_list(tail);
    // tail now points to the _last_ node in reversed_tail,
    // so tail->next must be null; tail can't be null itself        
    tail->next = head; 
    head->next = nullptr;
    return reversed_tail;
}

(未经测试......)

答案 1 :(得分:1)

列表反转函数必须是尾递归的,否则在递归长列表时它会溢出堆栈。 E.g:

node* reverse(node* n, node* prev = nullptr) {
    if(!n)
        return prev;
    node* next = n->next;
    n->next = prev;
    return reverse(next, n);
}

可以更容易地内联迭代列表反转:

inline node* reverse(node* n) {
    node* prev = nullptr;
    while(n) {
        node* next = n->next;
        n->next = prev;
        prev = n;
        n = next;
    }
    return prev;
}