题目链接:Swap Nodes in Pairs
Given a linked list, swap every two adjacent nodes and return its head.
For example,
Given 1->2->3->4, you should return the list as 2->1->4->3.
Your algorithm should use only constant space. You may not modify the values in the list, only nodes itself can be changed.
这道题的要求是交换链表中相邻的节点。要求:使用恒定空间,不允许修改链表中的数值,仅可以改变链表节点本身。
这道题考察的是链表处理,同样还是现在链表前面加个头,便于统一处理链表的所有节点。
假设链表为:
head -> 1 -> 2 -> 3 -> 4 -> NULL。
加头之后为:
h -> 0 -> 1 -> 2 -> 3 -> 4 -> NULL。
可先领p指向要交换节点的第一个节点的前一节点,temp指向要交换节点的第一个节点,即:
h -> 0 -> 1 -> 2 -> 3 -> 4 -> NULL
^ ^
| |
p temp
接下来,要使1和2两个节点交换,只需要交换其指针指向即可,即先将p->next指向节点2:
|-------->|
h -> 0 1 -> 2 -> 3 -> 4 -> NULL
^ ^
| |
p temp
然后temp->next指向节点3:
|-------->|
h -> 0 1 2 -> 3 -> 4 -> NULL
^ |-------->|
| ^
p |
temp
最后再使节点2的next指回节点1:
|-------->|
h -> 0 1 <- 2 3 -> 4 -> NULL
^ |-------->|
| ^
p |
temp
即:
h -> 0 -> 2 -> 1 -> 3 -> 4 -> NULL
^ ^
| |
p temp
接下来再移动p指针到下一要交换节点对的前面(即temp处)即可:
h -> 0 -> 2 -> 1 -> 3 -> 4 -> NULL
^
|
p
进而继续交换节点3和节点4,以此类推,进行循环。。。
时间复杂度:O(n)
空间复杂度:O(1)
1 class Solution
2 {
3 public:
4 ListNode *swapPairs(ListNode *head)
5 {
6 ListNode *h = new ListNode(0), *p = h;
7 h -> next = head;
8
9 while(p -> next != NULL && p -> next -> next != NULL)
10 {
11 ListNode *temp = p -> next;
12 p -> next = temp -> next;
13 temp -> next = p -> next -> next;
14 p -> next -> next = temp;
15 p = temp;
16 }
17
18 return h -> next;
19 }
20 };