1. 题目来源
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;
}
};