题解 | 反转链表
反转链表
https://www.nowcoder.com/practice/75e878df47f24fdc9dc3e400ec6058ca
class Solution {
ListNode* last = nullptr;
ListNode* recum(ListNode* head)
{
if(head == nullptr || head->next == nullptr)
{
last = head;
return last;
}
recum(head->next);
if(head->next->next == nullptr)
{
ListNode* next = head->next;
next->next = head;
head->next = nullptr;
}
return last;
}
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param head ListNode类
* @return ListNode类
*/
ListNode* ReverseList(ListNode* head) {
return recum(head);
}
};
1. 先考虑一个点:这个直接返回head。
2. 再考虑两个点:
ListNode* next = head->next; head->next = next->next; next->next = head;
3. 考虑三个点,按照上面的步骤,从后面开始进行反转,即:
1、从后往前,先反转2和3
2、此时回到上一层,现在到了1,那么就反转1和3
因此整个迭代过程就如第3种,从后往前,每次交换两个点,核心操作是2中的代码,即head->next->next == nullptr。
但是要注意的是,整个链表反转过来后,head就是最后一个链表节点,这在整个过程中是不会发生改变的,因此还需要用一个全局变量去保存这个last,并且最后也是返回这个last。
