206. 反转链表

递归的话,返回链表尾部的节点作为头节点。

reverse(node)函数是反转包括node在内的后面的链表,但是此时node节点的next指针还没处理。

当我们处理到正序pre-> node 时,node之后的链表反转,此时node的next为空,回溯到pre的时候,

让node的next指向pre,pre的next指向NULL

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        if (head==NULL || head->next==NULL) {
            return head;
        }
        ListNode* p=reverseList(head->next);
        head->next->next=head;
        head->next=NULL;
        return p;
    }
};
posted @ 2020-05-17 21:27  xyee  阅读(136)  评论(0编辑  收藏  举报