递归专题(3)——反转链表

🔥近津薪荼:个人主页

🎬个人专栏:《c语言基础知识详解》《c++基础知识详解》《Linux操作系统及网络基础知识分享》《近津薪荼的算法日迹》

✨体验生活,而不是演绎完美


1.上期参考代码

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* mergeTwoLists(ListNode* l1, ListNode* l2) {
        if(l1==nullptr)return l2;
        if(l2==nullptr)return l1;
        if(l1->val<=l2->val)
        {
            l1->next=mergeTwoLists(l1->next,  l2);
            return l1;
        }else
        {
            l2->next=mergeTwoLists(l1,  l2->next);
            return l2;
        }

    }
};

2.本期知识点导图

3.本期要讲解的题目是:

反转链表

要点:

迭代与递归两种方法

本期的题目超级简单 ,主要是在让大家感受一下,递归的宏观写法和具体写法之间微妙的联系

大家可以尝试自己先用递归写写看

4.解题

4.1迭代法:

cpp 复制代码
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        ListNode* prev = nullptr;
        ListNode* curr = head;
        while (curr) {
            ListNode* next = curr->next;
            curr->next = prev;
            prev = curr;
            curr = next;
        }
        return prev;
    }
};

4.2递归

4.2.1宏观视角(把递归函数看成f)

重复子问题:反转链表
子问题具体需要解决什么:将已知的传来的头节点尾插到反转好的链表中(将head->next

扔给f,就不管了,只需要处理一个头结点的指向

出口:head==nullptr(传来的时候就是空链表)或者head->next==nullptr

4.2.2具体视角

我们可以把链表看成特殊的树来看

(上一期也提到了递归与树的遍历逻辑的相似性),对树进行后序遍历(bfs),虽然处理方式相同,但要考虑所有节点的处理方式

大家自己动手写写代码,会发现两种视角写出来的代码是一模一样的,神奇不

5.下期要讲解的题目是:

两两交换链表中的节点

这题也非常简单,尝试做一做

相关推荐
我想我不够好。1 分钟前
2026.5.20 消防监控学习 1.5hour
学习
爱写代码的小朋友2 分钟前
基于多约束遗传算法的中小学排座位优化模型研究
linux·人工智能·算法
один but you5 分钟前
unorder_map 和unorder_set
算法·哈希算法·散列表
sheeta199817 分钟前
LeetCode 每日一题笔记 日期:2026.05.20 题目:2657. 找到前缀公共数组
笔记·算法·leetcode
无限进步_23 分钟前
C++异常机制:抛出、捕获与栈展开
开发语言·c++·安全
爱喝水的鱼丶27 分钟前
SAP-ABAP:数据类型与数据对象(8篇) 第七篇:进阶优化篇——基于类型与对象特征的性能优化技巧
运维·数据库·学习·性能优化·sap·abap·开发交流
数智工坊34 分钟前
【UniT论文阅读】:用统一物理语言打通人类与人形机器人的知识壁垒
论文阅读·人工智能·深度学习·算法·机器人
王老师青少年编程36 分钟前
csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维前缀和】:宝石串
c++·前缀和·csp·高频考点·信奥赛·宝石串
梓䈑36 分钟前
【算法题攻略】模拟
c++·算法
知识分享小能手38 分钟前
Flask入门学习教程,从入门到精通, 认识Flask路由 — 知识点详解 (2)
python·学习·flask