翻转链表2

发布于 2023-05-04 19:27:06 字数 682 浏览 42 评论 0

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

function reverseBetween(head, left, right) {
    // 创建一个虚拟头节点,方便处理头节点的情况
    const dummy = new ListNode(0);
    dummy.next = head;
    let pre = dummy;
    // 找到翻转区间的前一个节点
    for (let i = 0; i < left - 1; i++) {
        pre = pre.next;
    }
    let cur = pre.next;
    // 翻转区间的第一个节点
    let tail = cur;
   
    // 翻转区间内的节点
    for (let i = left; i <= right; i++) {
        const next = cur.next;
        cur.next = pre.next;
        pre.next = cur;
        cur = next;
    }
    // 将翻转区间内的最后一个节点指向下一个节点
    tail.next = cur;
    return dummy.next;
};

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

夏了南城

暂无简介

0 文章
0 评论
23 人气
更多

推荐作者

qq_eQNo9e

文章 0 评论 0

内心旳酸楚

文章 0 评论 0

mb_BlPo2I8v

文章 0 评论 0

alipaysp_ZRaVhH1Dn

文章 0 评论 0

alipaysp_VP2a8Q4rgx

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文