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

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

相关推荐
JasmineX-12 小时前
数据结构(笔记)——双向链表
c语言·数据结构·笔记·链表
嘻嘻哈哈樱桃5 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划
脱氧核糖核酸__5 小时前
LeetCode热题100——234.回文链表(两种解法)
c++·算法·leetcode·链表
电科一班林耿超5 小时前
第 16 课:动态规划专题(二)—— 子序列与子数组问题:面试最高频的 DP 题型
数据结构·算法·动态规划
hnjzsyjyj5 小时前
洛谷 B3622:枚举子集(递归实现指数型枚举)← DFS
数据结构·dfs
6Hzlia6 小时前
【Hot 100 刷题计划】 LeetCode 24. 两两交换链表中的节点 | C++ 精准指针舞步
c++·leetcode·链表
qiqsevenqiqiqiqi7 小时前
MT2048三连 暴力→数学推导→O (n) 优化
数据结构·c++·算法
码之气三段.7 小时前
十五届山东ccpc省赛补题(update)
数据结构·c++·算法
保持清醒5409 小时前
二叉链表实现
数据结构
paeamecium9 小时前
【PAT甲级真题】- Recover the Smallest Number (30)
数据结构·算法·pat考试·pat