递归专题(4)——两两交换链表中的节点

本期知识点导图:

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* reverseList(ListNode* head)
   {
        if(head==nullptr||head->next==nullptr)//注意顺序
        {
           return head;
        }
        ListNode* newhead=reverseList(head->next);  
       head->next->next=head;
       head->next=nullptr;
       return newhead;
    }
};

代码写出来真的一样耶,神奇不~

后边我们遇到递推,直接无脑宏观就得,不要再死磕具体了

2.本期知识点导图

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

两两交换链表中的节点

要点:

从头开始,两两交换相同节点

只改变指向,不改变值

返回头结点

这题也是非常ez啊,拿来给大家练练手刚好合适

4.解题

1.重复子问题:俩俩交换剩余链表相邻元素

2.子问题具体做什么:俩俩交换相邻元素

3.出口:剩余链表不足俩元素

5.下期要讲解的题目是

Pow(x, n)快速幂

下期见。

相关推荐
辰海Coding3 小时前
MiniSpring框架学习笔记-解决循环依赖的简化IoC容器
笔记·学习
杜子不疼.3 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
晓梦林3 小时前
cp520靶场学习笔记
android·笔记·学习
石山代码4 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家4 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
Upsy-Daisy4 小时前
AI Agent 项目学习笔记(八):Tool Calling 工具调用机制总览
人工智能·笔记·学习
绝知此事4 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院4 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet5 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展