【算法】递归系列:206.反转链表(两种递归实现)

目录

1、题目链接

2、题目介绍

3、解法

递归法(从前往后递归)

从后往前递归

4、代码

递归法(从前往后递归)

从后往前递归


1、题目链接

206.反转链表

2、题目介绍

3、解法

递归法(从前往后递归)

递归的过程中,记录下当前节点的下一节点,然后将当前节点的next指针指向前一节点,不断递归

从后往前递归

首先判断边缘,当head为空返回空,当head-》next为空就返回head即可,然后调用该函数递归下一个节点,这样就一直递归到最后一个节点,将最后一个节点的next指针指向前一个结点,一直这样递归,然后返回递归后的链表即可

4、代码

递归法(从前往后递归)

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* reverse(ListNode* newhead, ListNode* head2)
    {
        //从前向后 ,进行翻转递归
        
        //newhead  翻转链表之后的"新头节点"
        //head2   剩余链表的头节点
        if (head2 == NULL)
            return newhead;

        //temp存储原链表
        ListNode* temp = head2->next;
        //翻转,更新 反转链表 的头节点为head2
        head2->next = newhead;

        return reverse(head2, temp);

    }
        ListNode* reverseList(ListNode* head) {
            return reverse(NULL, head);
    }
};

从后往前递归

cpp 复制代码
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        if(head==NULL)return NULL;

        if(head->next==NULL)return head;

        ListNode*pre=reverseList(head->next);

        head->next->next=head;//让后一个节点指向自己
        head->next=NULL;

        return pre;
}
相关推荐
碧海银沙音频科技研究院2 分钟前
DiVE长尾识别的虚拟实例蒸馏方法
arm开发·人工智能·深度学习·算法·音视频
居7然1 小时前
DeepSeek OCR:重新定义AI文档处理的“降本增效”新范式
人工智能·算法·语言模型·自然语言处理·大模型·ocr
while(1){yan}2 小时前
数据结构之堆
数据结构·python·算法
SleepyWhite0012 小时前
代码随想录Day61|Floyd 算法精讲、A * 算法精讲
算法·floyd算法·astar算法
Miraitowa_cheems2 小时前
LeetCode算法日记 - Day 84: 乘积为正数的最长子数组长度
数据结构·算法·leetcode·贪心算法·线性回归·深度优先·动态规划
雾岛听蓝2 小时前
C语言:使用顺序表实现通讯录
c语言·数据结构·经验分享·笔记·visualstudio
不是老弟3 小时前
rwqsd
数据结构·c++·算法
小龙报3 小时前
《C语言疑难点 --- 字符函数和字符串函数专题(上)》
c语言·开发语言·c++·算法·学习方法·业界资讯·visual studio
程序员阿鹏3 小时前
560.和为k的子数组
数据结构