[路飞]_leetcode-92-反转链表 II

简介: leetcode-92-反转链表 II

网络异常,图片无法展示
|


「这是我参与11月更文挑战的第22天,活动详情查看:2021最后一次更文挑战


[题目地址][B站地址]


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


示例 1:


网络异常,图片无法展示
|


输入: head = [1,2,3,4,5], left = 2, right = 4
输出: [1,4,3,2,5]
复制代码


示例 2:


输入: head = [5], left = 1, right = 1
输出: [5]
复制代码


提示:


  • 链表中节点数目为 n
  • 1 <= n <= 500
  • -500 <= Node.val <= 500
  • 1 <= left <= right <= n


进阶:  你可以使用一趟扫描完成反转吗?


本题其实就是查找指定节点与反转链表的结合而已


主体思路即:首先找到待反转区间,将待反转区间反转,然后再接回原链表即可

详细解题思路如下:


  1. 特判:如果 left===right 则不需要反转,直接返回原链表即可
  2. 创建虚拟头节点 vhead,vhead.next = head,虚拟头可以方便我们后续的操作(举例:如果待反转区间包含头节点,则返回值特殊判断,有了虚拟头只要返回 vhead.next 即可)
  3. 定义三个指针 pre = vheadstart = headend = head
  4. 根据 leftright 的值向后调整 prestartend 的位置为待反转区间的前一个节点,待反转区间的开始位置和结束位置
  5. 通过 end.next 获取待反转区间的下一个节点 nextHead
  6. 编写 reverse 函数反转待反转区间并返回反转后链表的头尾节点(对链表反转不熟悉的小伙伴可以看我之前这篇文章 《反转链表》
  7. 通过之前记录的 pre 指针连接反转后链表的头节点,通过 nextHead 连接返回链表的尾节点
  8. 最后返回 vhead.next 即可


完整过程如下:


网络异常,图片无法展示
|


代码如下:


// 反转链表
function reverse(start,end){
  let pre = start,
  next = start.next;
  // 从后向前的反转next指针
  while(next!==end){
    const next_next = next.next;
    next.next = pre;
    pre = next;
    next = next_next;
  }
  next.next = pre;
  return [end,start]
}
var reverseBetween = function(head, left, right) {
  // 如果 left===right 则不需要反转
  if(left === right) return head;
  // 创建虚拟头节点
  const vhead = new ListNode(0);
  vhead.next = head;
  // 待反转区间的前一个节点
  let pre = vhead,
  // 待反转区间的头尾节点
  start = end = head;
  // 找到待反转区间
  while(right>1){
    left--,right--;
    if(left>0){
      pre = pre.next;
      start = start.next;
    }
    end = end.next;
  }
  // 待反转区间的下一个节点
  const nextHead = end.next;
  // 反转待反转区间
  [start,end] = reverse(start,end);
  // 将反转后的链表区间链接到原链表中
  pre.next = start;
  end.next = nextHead;
  return vhead.next;
};
复制代码


至此我们就完成了 leetcode-92-反转链表 II


如有任何问题或建议,欢迎留言讨论!

相关文章
|
3月前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
46 1
|
3月前
Leetcode第21题(合并两个有序链表)
这篇文章介绍了如何使用非递归和递归方法解决LeetCode第21题,即合并两个有序链表的问题。
59 0
Leetcode第21题(合并两个有序链表)
|
3月前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
34 0
LeetCode第二十四题(两两交换链表中的节点)
|
3月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
50 0
Leetcode第十九题(删除链表的倒数第N个节点)
|
3月前
|
索引
力扣(LeetCode)数据结构练习题(3)------链表
力扣(LeetCode)数据结构练习题(3)------链表
112 0
|
3月前
【LeetCode 10】142. 环形链表 II
【LeetCode 10】142. 环形链表 II
29 0
|
3月前
【LeetCode 09】19 删除链表的倒数第 N 个结点
【LeetCode 09】19 删除链表的倒数第 N 个结点
22 0
|
3月前
【LeetCode 08】206 反转链表
【LeetCode 08】206 反转链表
18 0
|
3月前
【LeetCode 06】203.移除链表元素
【LeetCode 06】203.移除链表元素
39 0
|
5月前
|
C++ 索引
leetcode 707.设计链表
本文提供了解决LeetCode 707题"设计链表"的C++实现,包括单链表的节点定义和类方法实现,如添加节点、获取节点值、删除节点等。