Leetcode_206.反转链表(递归)

这道题原本的方式是采用头插法来解决,现在有了一个新的思路,那就是递归

在设计递归时需要着重考虑的就是递归的终止条件,那么我们这个题的终止条件是什么呢?

在链表为空,或者链表为1个节点时,链表不需要反转,以此可以作为递归的终止条件,即:
head == nullptr || head->next == nullptr

结束条件有了,下来该写递归函数了。在没有达到终止条件时,应该反转链表,通过总体来看,当第一次反转时,应该反转 head->next 之后的链表,因为终止条件为 head == nullptr || head->next == nullptr,所以递归调用参数应该是 head->next,这样才能让递归逐步向链表尾部推进,直到触发终止条件。然后在回溯过程中,通过 head->next->next = head 来反转指针方向,完成整个链表的反转。

整个递归过程是从后向前的,在处理 1 节点是 , 链表已经变为了 5 -> 4 -> 3 -> 2 ->nullptr ,此时回溯就需要将2指向1 ,1指向nullptr,那么 2 这个节点的地址该如何获取呢?

可以在进行递归之前先获取这个节点的地址 ListNode * tail=head->next,由此获取节点2的地址,回到上面 就变为 1->next=tail->next(nullptr) ;2->next =1;,翻译一下也就是 head->next =tail->next; tail->next =head ;

ac代码:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    
    ListNode* reverseList(ListNode* head) {
        if(head==nullptr||head->next==nullptr) return head;
        ListNode *tail=head->next;
        ListNode * new_head=reverseList(head->next);
        head->next=tail->next;
        tail->next=head;
        return new_head;

    }
};
相关推荐
明洞日记36 分钟前
【VTK手册027】VTK 颜色连续映射:vtkColorTransferFunction 深度解析与实战指南
c++·图像处理·算法·vtk·图形渲染
B_lack0261 小时前
西门子PLC结构化编程_线性插值算法功能块
算法·pid·西门子plc·博途·线性插值·开环控制
fufu03111 小时前
Linux环境下的C语言编程(四十三)
linux·c语言·算法
业精于勤的牙2 小时前
三角形最小路径和(二)
算法
风筝在晴天搁浅2 小时前
hot100 239.滑动窗口最大值
数据结构·算法·leetcode
夏乌_Wx2 小时前
练题100天——DAY31:相对名次+数组拆分+重塑矩阵
数据结构·算法
LYFlied2 小时前
【算法解题模板】-解二叉树相关算法题的技巧
前端·数据结构·算法·leetcode
Ven%2 小时前
【AI大模型算法工程师面试题解析与技术思考】
人工智能·python·算法
天勤量化大唯粉2 小时前
枢轴点反转策略在铜期货中的量化应用指南(附天勤量化代码)
ide·python·算法·机器学习·github·开源软件·程序员创富
爱学习的小仙女!2 小时前
算法效率的度量 时间复杂度 空间复杂度
数据结构·算法