给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
主要解题思想是:以节点1 2 3 4 5 6的链表举例,首先保存节点3的指针,将节点2指向节点1,进入循环将节点1指向节点4,保存节点5的指针,将节点4指向节点3,,然后下一次循环将节点3指向节点6……依此类推。画图可知。
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* swapPairs(ListNode* head) {
ListNode* p=head;//p=头节点
if(p!=nullptr && p->next!=nullptr){//初始时至少2个节点
head=head->next;//更改头节点
ListNode* pNextPos=p->next->next;//后2个节点的起始位置
p->next->next=p;//节点2指向节点1
//每次移动两个节点 与前两个节点一起表示为 -2 -1 1 2节点
while(pNextPos!=nullptr && pNextPos->next!=nullptr){//如果后面至少有2个节点
p->next=pNextPos->next;//节点-2指向节点2
p=pNextPos;//p=节点1
pNextPos=p->next->next;//pNextPos=节点2的下一个节点
p->next->next=p;//节点2指向节点1
}
p->next=pNextPos;//将p的指向置空/或最后一个单节点 免得最后两个节点构成循环
}
return head;
}
};