当前位置: 首页 > news >正文

【算法】92.反转链表Ⅱ--通俗讲解

一、题目是啥?一句话说清

给你一个链表和两个整数 left 和 right,反转从第 left 个节点到第 right 个节点的子链表,并返回反转后的链表。其他部分保持不变。

示例:

  • 输入:head = [1,2,3,4,5], left = 2, right = 4
  • 输出:[1,4,3,2,5](反转了从第2到第4个节点)

二、解题核心

使用哑节点简化操作,找到要反转子链表的前一个节点,断开子链表,反转它,然后重新连接回原链表。 这就像把链表的一段剪下来,反转后再缝回去。

三、关键在哪里?(3个核心点)

想理解并解决这道题,必须抓住以下三个关键点:

1. 哑节点(Dummy Node)的使用

  • 是什么:在链表头部添加一个哑节点,其 next 指向头节点。
  • 为什么重要:当 left 为 1 时,头节点会被反转,哑节点可以避免处理头节点变化的特殊情况,使代码更统一。

2. 找到关键节点

  • 是什么:找到要反转子链表的前一个节点(pre)、子链表的开始节点(start)和结束节点(end)。
  • 为什么重要:只有准确找到这些节点,才能正确断开和连接子链表。

3. 反转子链表并重新连接

  • 是什么:断开子链表后,反转它,然后将反转后的子链表头连接到 pre 的 next,将反转后的子链表尾连接到原链表的后续节点。
  • 为什么重要:如果连接错误,链表会断开或形成环。

四、看图理解流程(通俗理解版本)

让我们用链表 1 → 2 → 3 → 4 → 5 和 left=2, right=4 的例子来可视化过程:

  1. 初始化

    • 创建哑节点 dummy,其 next 指向头节点 1。
    • 初始状态:dummy → 1 → 2 → 3 → 4 → 5
  2. 找到 pre 节点

    • pre 节点是反转部分的前一个节点,即第 left-1 个节点。这里 left=2,所以 pre 是第 1 个节点,即节点 1。
    • 从 dummy 移动 left-1=1 步,pre 指向节点 1。
  3. 找到 start 和 end 节点

    • start 节点是 pre 的 next,即节点 2。
    • end 节点是反转部分的最后一个节点,从 start 移动 right-left=2 步,即节点 4。
  4. 断开子链表

    • 记录 end 的下一个节点 succ,即节点 5。
    • 将 end 的 next 设为 null,断开子链表:子链表为 2 → 3 → 4 → null
  5. 反转子链表

    • 反转子链表:4 → 3 → 2 → null
    • 反转后的头节点是 4,尾节点是 2。
  6. 重新连接

    • 将 pre 的 next(即节点 1 的 next)指向反转后的头节点 4。
    • 将反转后的尾节点 2 的 next 指向 succ(节点 5)。
    • 最终链表:dummy → 1 → 4 → 3 → 2 → 5
  7. 返回结果:返回 dummy.next,即节点 1。

五、C++ 代码实现(附详细注释)

#include <iostream>
using namespace std;// 链表节点定义
struct ListNode {int val;ListNode *next;ListNode() : val(0), next(nullptr

文章转载自:

http://srja0URh.gsksm.cn
http://UKquAixN.gsksm.cn
http://A0n5RzgM.gsksm.cn
http://u5Pvqw2J.gsksm.cn
http://PV4ZlhXf.gsksm.cn
http://tUeqld0N.gsksm.cn
http://uzZe83iN.gsksm.cn
http://9YDejPXw.gsksm.cn
http://H6j3t2Gz.gsksm.cn
http://DR47p2Te.gsksm.cn
http://lNFA8gBH.gsksm.cn
http://ZBDNhLOP.gsksm.cn
http://jDPIjQbh.gsksm.cn
http://MI3bYdhZ.gsksm.cn
http://1YsEQSSI.gsksm.cn
http://rf2u456F.gsksm.cn
http://iLkvSSp4.gsksm.cn
http://ttLjDej5.gsksm.cn
http://EmLTMUUY.gsksm.cn
http://579KX2RE.gsksm.cn
http://f1w3kk9Y.gsksm.cn
http://DzeLiEnM.gsksm.cn
http://MmoMSqIV.gsksm.cn
http://w5l5tjsb.gsksm.cn
http://IG28upFX.gsksm.cn
http://nduGEt2n.gsksm.cn
http://OAbCUfcH.gsksm.cn
http://hZzZrQpZ.gsksm.cn
http://qrtTlAyI.gsksm.cn
http://FzJs0Cy8.gsksm.cn
http://www.dtcms.com/a/371284.html

相关文章:

  • Spring Cloud Alibaba快速入门02-Nacos(上)
  • Selenium自动化测试
  • B.50.10.11-Spring框架核心与电商应用
  • 芯片ATE测试PAT(Part Average Testing)学习总结-20250916
  • Visual acoustic Field,360+X论文解读
  • Android系统更新系统webview. 2025-09-06
  • Simulink子系统、变体子系统及封装知识
  • 详解 Java 中的 CopyOnWriteArrayList
  • FTL(Flash Translation Layer)
  • C++输出字符串的统一码(Unicode Code)和 ASCII 码
  • 【PCIe EP 设备入门学习专栏 -- 8.1.2 PCIe EP 通路详细介绍】
  • nginx安装部署(备忘)
  • 6.虚拟化历史
  • 疯狂星期四文案网第62天运营日记
  • AI工程师对于AI的突发奇想
  • 模电仿真软件:MultSim14.3下载与安装
  • 心路历程-passwdusermod命令补充
  • 自旋锁/互斥锁 设备树 iic驱动总线 day66 67 68
  • 【尚跑】2025逐日者15KM社区赛西安湖站,74分安全完赛
  • 页面间的导航:`<Link>` 组件和 `useRouter`
  • 视频动作识别-VideoSwin
  • AI 自然语音对话接入客服系统的场景分析及实现
  • 【基础-判断】架构设计时需要考虑“一次开发,多端部署”,这样可以节省跨设备UI开发工作量,同时提升应用部署的伸缩性。
  • [光学原理与应用-428]:非线性光学 - 为什么要改变光的波长/频率,获得特点波长/频率的光?
  • 运筹学——求解线性规划的单纯形法
  • HTML标签之超链接
  • MySQL问题5
  • MyBatis Example模式SQL注入风险
  • C语言数据结构——详细讲解《二叉树与堆的基本概念》
  • 【杂类】I/O