递归专题(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.下期要讲解的题目是:

两两交换链表中的节点

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

相关推荐
Tisfy1 小时前
LeetCode 3013.将数组分成最小总代价的子数组 II:两个堆维护k-1小 + 滑动窗口
算法·leetcode·题解·优先队列··有序集合·滑动窗口
code monkey.1 小时前
【Linux之旅】Linux 动静态库与 ELF 加载全解析:从制作到底层原理
linux·服务器·c++·动静态库
爱吃汽的小橘1 小时前
揭秘802.15.4:物联网通信基石
网络·学习
坚持就完事了1 小时前
Java算法:递归
算法
I'mChloe2 小时前
机器学习核心分支:深入解析监督学习
人工智能·学习·机器学习
senijusene2 小时前
数据结构与算法:完全二叉树和非完全二叉数的各种详细操作以及哈希表的简单应用
数据结构·算法·链表
水饺编程2 小时前
第4章,[标签 Win32] :文本的格式化,等待完善
c语言·c++·windows·visual studio
LYS_06182 小时前
寒假学习(13)(HAL库4+模数电13)
单片机·嵌入式硬件·学习
一点程序2 小时前
基于微信小程序的英语词汇学习小程序
学习·微信小程序·小程序