[M链表] lc24. 两两交换链表中的节点(链表+链表反转)

1. 题目来源

链接:24. 两两交换链表中的节点

2. 题目解析

在这里插入图片描述
链表题目建议画图理解。本题每次逆转两个链表元素,首先头结点可能会发生改变,则使用虚拟头结点即可。建立三个指针一开始指向虚拟头结点即 head 节点的前一个、实际 head 节点、head 节点的下一个。经过如上三步转换即可发现 p 节点的后两个被成功逆置,能发现每次都会将 p 指针的后两个成功逆置,每次更新一下 p=a 即可,让 p 指向待逆置的节点的前一个,继续逆置下两个节点即可。

注意交换顺序。


  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度 O ( 1 ) O(1) O(1)

代码:

class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        auto dummy = new ListNode(-1);
        dummy->next = head;
        for (auto p = dummy; p->next && p->next->next; ) {
            auto a = p->next, b = a->next;
            p->next = b, a->next = b->next, b->next = a;
            p = a;
        }
        return dummy->next;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ypuyu

如果帮助到你,可以请作者喝水~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值