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

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

相关推荐
汀、人工智能29 分钟前
[特殊字符] 第21课:最长有效括号
数据结构·算法·数据库架构·图论·bfs·最长有效括号
Boop_wu1 小时前
[Java 算法] 字符串
linux·运维·服务器·数据结构·算法·leetcode
故事和你911 小时前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
迈巴赫车主3 小时前
蓝桥杯3500阶乘求和java
java·开发语言·数据结构·职场和发展·蓝桥杯
高一要励志成为佬4 小时前
【数据结构】算法复杂度
数据结构
香蕉鼠片5 小时前
数据结构八股(一)
数据结构·算法
起个破名想半天了5 小时前
算法与数据结构之排序
数据结构·排序算法·排序·算法与数据结构
abant26 小时前
leetcode 114 二叉树变链表
算法·leetcode·链表
派大星~课堂7 小时前
【力扣-148. 排序链表】Python笔记
python·leetcode·链表
_深海凉_8 小时前
LeetCode热题100-环形链表
算法·leetcode·链表