【算法】递归系列: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;
}
相关推荐
XH华29 分钟前
初识C语言之二维数组(下)
c语言·算法
南宫生1 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
不想当程序猿_1 小时前
【蓝桥杯每日一题】求和——前缀和
算法·前缀和·蓝桥杯
落魄君子1 小时前
GA-BP分类-遗传算法(Genetic Algorithm)和反向传播算法(Backpropagation)
算法·分类·数据挖掘
菜鸡中的奋斗鸡→挣扎鸡1 小时前
滑动窗口 + 算法复习
数据结构·算法
Lenyiin2 小时前
第146场双周赛:统计符合条件长度为3的子数组数目、统计异或值为给定值的路径数目、判断网格图能否被切割成块、唯一中间众数子序列 Ⅰ
c++·算法·leetcode·周赛·lenyiin
郭wes代码2 小时前
Cmd命令大全(万字详细版)
python·算法·小程序
scan7242 小时前
LILAC采样算法
人工智能·算法·机器学习
菌菌的快乐生活2 小时前
理解支持向量机
算法·机器学习·支持向量机
大山同学2 小时前
第三章线性判别函数(二)
线性代数·算法·机器学习