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

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

相关推荐
IronMurphy7 分钟前
【算法二十五】105. 从前序与中序遍历序列构造二叉树 236. 二叉树的最近公共祖先
java·数据结构·算法
像污秽一样27 分钟前
算法设计与分析-习题8.2
数据结构·算法·排序算法·dfs·化简
玛卡巴卡ldf28 分钟前
【LeetCode 手撕算法】(子串) 560-和为 K 的子数组
java·数据结构·算法·leetcode
无限进步_39 分钟前
深入解析list:一个完整的C++双向链表实现
开发语言·c++·git·链表·github·list·visual studio
不想看见40439 分钟前
Rotate Image数组--力扣101算法题解笔记
数据结构·算法
仰泳的熊猫1 小时前
题目 2304: 蓝桥杯2019年第十届省赛真题-特别数的和
数据结构·c++·算法·蓝桥杯
像污秽一样1 小时前
算法设计与分析-习题4.3
数据结构·算法·排序算法
沈阳信息学奥赛培训1 小时前
C++ 指针* 和 指针的引用 *& (不是指针和引用,是指针的引用)
数据结构·c++·算法
会编程的土豆2 小时前
【数据结构与算法】 树
数据结构·算法
喵喵蒻葉睦2 小时前
力扣 hot100 滑动窗口最大值 单调双端队列 java 简单题解
java·数据结构·算法·leetcode·双端队列·滑动窗口·队列