【算法题】92. 反转链表 II

题目

给你单链表的头指针 head 和两个整数 left 和 right ,其中 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
 

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

题解

class Solution {
    public ListNode reverseBetween(ListNode head, int left, int right) {
        // 因为头节点有可能发生变化,使用虚拟头节点可以避免复杂的分类讨论
        ListNode dummyNode = new ListNode(-1);
        dummyNode.next = head;

        ListNode pre = dummyNode;
        // 第 1 步:从虚拟头节点走 left - 1 步,来到 left 节点的前一个节点
        // 建议写在 for 循环里,语义清晰
        for (int i = 0; i < left - 1; i++) {
            pre = pre.next;
        }

        // 第 2 步:从 pre 再走 right - left + 1 步,来到 right 节点
        ListNode rightNode = pre;
        for (int i = 0; i < right - left + 1; i++) {
            rightNode = rightNode.next;
        }

        // 第 3 步:切断出一个子链表(截取链表)
        ListNode leftNode = pre.next;
        ListNode curr = rightNode.next;

        // 注意:切断链接
        pre.next = null;
        rightNode.next = null;

        // 第 4 步:同第 206 题,反转链表的子区间
        reverseLinkedList(leftNode);

        // 第 5 步:接回到原来的链表中
        pre.next = rightNode;
        leftNode.next = curr;
        return dummyNode.next;
    }

    private void reverseLinkedList(ListNode head) {
        // 也可以使用递归反转一个链表
        ListNode pre = null;
        ListNode cur = head;

        while (cur != null) {
            ListNode next = cur.next;
            cur.next = pre;
            pre = cur;
            cur = next;
        }
    }
}

来自力扣官方题解

相关推荐

  1. 算法92. II

    2024-02-08 01:52:01       27 阅读
  2. leetcode 92. II

    2024-02-08 01:52:01       11 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-08 01:52:01       14 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-08 01:52:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-08 01:52:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-08 01:52:01       18 阅读

热门阅读

  1. 分支解决冲突 & 分支管理策略 git merge命令详解

    2024-02-08 01:52:01       31 阅读
  2. 【Git】三棵“树”介绍

    2024-02-08 01:52:01       34 阅读
  3. (39)统计位数为偶数的数字

    2024-02-08 01:52:01       34 阅读
  4. work day7

    2024-02-08 01:52:01       27 阅读
  5. PyTorch自动微分模块torch.autograd的详细介绍

    2024-02-08 01:52:01       29 阅读
  6. 蓝桥杯-“山”形数字个数(python版)

    2024-02-08 01:52:01       31 阅读