Leetcode 刷题 92. 反转链表 II

很多前端的同学对数据结构和算法这块没有太多的概念,很多leetcode的题目看不懂,有时候可能看了题解也不知道是什么意思。上一篇我们对链表的数据结构有了了解,下面根据题目来练习一下

92. 反转链表 II

题目

给你单链表的头指针 head 和两个整数 leftright ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表

题解

我们首先来看看下这道题的意思是什么。这道题目其实很好理解,给你两个位置left和right,让你反转从位置left到位置right的链表节点。

这里还是需要一个虚拟头节点,然后我们需要计算出需要反转的个数n,以及需要反转的起点。

题目中我们就可以知道从位置 left 到位置 right 进行反转,那么需要反转的个数n就可以通过right-left+1计算得到。反转的起点,我们可以通过从头节点开始向后走,走到left的前一位就可以。下面用图来表示一下

我们看下代码:

js 复制代码
// 定义一个哨兵元素
let ret = new ListNode(null, head)
// 最后需要返回的是ret 所以需要一个变量替换
let pre = ret
// 需要反转的个数
let n = right - left + 1
// 找到反转的起点
while (--left) {
    pre = pre.next
}

此时的pre就是反转的起点。剩下的就需要看看怎么反转了。从上篇文章Leetcode 刷题 206. 反转链表可以知道如何反转一个链表了。那现在反转的起点和需要反转的个数我们都已经知道,只需要对上篇文章的代码稍微修改一下就好了。

js 复制代码
var reverse = function (head, n) {
    let prev = null, cur = head
    while (n--) {
            [cur.next, prev, cur] = [prev, cur, cur.next]
    }
    // head此时已经变成了最后一个节点了, 所以他需要指向下一位,此时下一位是cur
    head.next = cur
    return prev
}

这里我们前6行的代码只需要将之前的循环条件改为n--就好了,因为需要反转n次。注意看第7行,当链表反转完毕之后,head已经是最后一个节点了,所以head的next节点需要指向下一位

如图,首先将需要反转的节点单独处理,反转完毕之后,head的节点其实已经是最后一个了,只需要将head的next指向cur就可以串联起来了。目前图中可以看到,反转后的那一段还有头需要连接

我们只需要在将pre的next节点指向反转后的节点就好了。 下面看下完整代码:

js 复制代码
var reverseBetween = function (head, left, right) {
    // 定义一个哨兵元素
    let ret = new ListNode(null, head)
    // 最后需要返回的是ret 所以需要一个变量替换
    let pre = ret
    // 需要反转的个数
    let n = right - left + 1
    // 找到反转的起点
    while (--left) {
        pre = pre.next
    }
    // 找到起点后开始反转
    pre.next = reverse(pre.next, n)
    return ret.next
};


var reverse = function (head, n) {
    let prev = null, cur = head
    while (n--) {
        [cur.next, prev, cur] = [prev, cur, cur.next]
    }
    // head此时已经变成了最后一个节点了, 所以他需要指向下一位,此时下一位是cur
    head.next = cur
    return prev
}

欢迎大家点赞评论,大家一起学习一起进步!!!

相关推荐
SunnyKriSmile38 分钟前
C语言译码操作
c语言·算法·if语句·译码操作·switch语句
小小小CTFER43 分钟前
理论题] 2025 年 “技耀泉城” 海右技能人才大赛网络安全知识竞赛题目(二)
算法·安全·web安全
断剑zou天涯3 小时前
【算法笔记】暴力递归尝试
java·笔记·算法
油泼辣子多加3 小时前
【实战】自然语言处理--长文本分类(1)DPCNN算法
算法·自然语言处理·分类
web打印社区4 小时前
使用React如何静默打印页面:完整的前端打印解决方案
前端·javascript·vue.js·react.js·pdf·1024程序员节
喜欢踢足球的老罗4 小时前
[特殊字符] PM2 入门实战:从 0 到线上托管 React SPA
前端·react.js·前端框架
I'm a winner4 小时前
基于YOLO算法的医疗应用专题:第一章 计算机视觉与深度学习概述
算法·yolo·计算机视觉
小光学长4 小时前
基于Vue的课程达成度分析系统t84pzgwk(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
vir024 小时前
P1928 外星密码(dfs)
java·数据结构·算法·深度优先·1024程序员节