LeetCode[Linked List]: Reverse Linked List II

本文介绍了一种在链表中反转指定区间的节点,并在原地进行操作且仅需一次遍历的方法。通过使用虚拟头结点技术,使得处理头结点变得简单。具体步骤包括初始化快慢指针,快指针前移n步,慢指针前移m步,然后依次将慢指针和快指针之间的节点插入快指针之后。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Reverse a linked list from position m to n. Do it in-place and in one-pass.
For example:
Given 1->2->3->4->5->NULL, m = 2 and n = 4,
return 1->4->3->2->5->NULL.
Note:
Given m, n satisfy the following condition:
1 ≤ m ≤ n ≤ length of list.

思路很简单:设置两个指针:fast往前移动n步,low往前移动m步,然后依次将low和fast之间的节点挨个插到fast的后面即可。注意:为去除头结点的特殊性,需要用到虚拟头结点技术。

ListNode *reverseBetween(ListNode *head, int m, int n) {
    ListNode *dummyHead = new ListNode(0);
    dummyHead->next = head;

    ListNode *fast = head;
    for (int i = 0; i < n - 1; ++i)
        fast = fast->next;

    ListNode *low  = dummyHead;
    for (int i = 0; i < m - 1; ++i)
        low  = low ->next;

    for (int i = 0; i < n - m; ++i) {
        ListNode *curr = low->next;
        low ->next = low ->next->next;
        curr->next = fast->next;
        fast->next = curr;
    }

    head = dummyHead->next;
    delete dummyHead;
    return head;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值