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

文章目录

    • 1. 题目来源
    • 2. 题目解析

1. 题目来源

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

2. 题目解析

[M链表] lc24. 两两交换链表中的节点(链表+链表反转)_第1张图片
链表题目建议画图理解。本题每次逆转两个链表元素,首先头结点可能会发生改变,则使用虚拟头结点即可。建立三个指针一开始指向虚拟头结点即 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;
    }
};

你可能感兴趣的:(LeetCode,LeetCode)