day5:92. 反转链表 II

这道题目是反转链表的升级版,难点在于局部反转后的链表指向,以反转下图中2-3-4为例:

从图中可以看出,除了区间的指针需要改变,区间的前驱节点指向和后继节点的被指向也要变化

为了确保前驱节点不为空,加入dummy虚拟节点,指向列表头节点

代码实现:

```js

/**

* @param {ListNode} head

* @param {number} left

* @param {number} right

* @return {ListNode}

*/

var reverseBetween = function(head, left, right) {

let dummy = new ListNode(0,head);

let pre = dummy;

for(let i=1;i<left;i++){

pre = pre.next;

}

let cur = pre.next;

for(let i=0;i<right-left;i++){

const next = cur.next;

cur.next = next.next;

next.next = pre.next;

pre.next = next;

}

return dummy.next;

};

```

头插法图示:

const next = cur.next;

cur.next = next.next;

next.next = pre.next;

pre.next = next;

注意几个点:

1. pre和cur的指向是固定的,next每次变化;

2. 每次循环要改变三个节点的指向,先改变cur,再改变next,最后是pre

本题的 "头插法",是迭代法针对 "局部反转" 场景的适配版本------ 本质都是通过循环(迭代)调整指针,只是操作方式更贴合 "局部反转" 的需求。

相关推荐
大黄说说2 小时前
解锁 .NET 性能极限:深入解析 Span 与零拷贝内存艺术
java·数据结构·算法
㓗冽2 小时前
纯粹合数(字符串)-基础题100th + 找出质数(字符串)-基础题101th + 翻译字符串(字符串)-基础题102th
数据结构·c++
二年级程序员2 小时前
一篇文章掌握“树”(上)
c语言·数据结构·算法
@insist1232 小时前
软考-软件设计师-数据表示核心考点详解:从进制转换到 IEEE 754 标准
java·数据结构·算法
NGC_66112 小时前
【无标题】
数据结构·算法·排序算法
NGC_66112 小时前
快速排序算法
数据结构·算法·排序算法
Darkwanderor2 小时前
离散化思维的应用
数据结构·c++·算法·哈希算法
代码改善世界10 小时前
【数据结构与算法】栈和队列题解
数据结构
ShineWinsu10 小时前
对于C++:继承的解析—上
开发语言·数据结构·c++·算法·面试·笔试·继承