给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。
你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
示例:
给定 1->2->3->4, 你应该返回 2->1->4->3.
tips : 原地交换,时间复杂度O(n), 空间复杂度O(1)
class Solution {
public:
ListNode* swapPairs(ListNode* head) {
if(head==NULL) {
return NULL;
}
ListNode* node=new ListNode(-1);
ListNode* init=node;
ListNode* swapA;
ListNode* nextHead;
node->next = head;
while (node->next!=NULL&&node->next->next!=NULL)
{
swapA=node->next;
if(node->next->next!=NULL) {
node->next=node->next->next;
nextHead=node->next->next;
node->next->next=swapA;
swapA->next=nextHead;
node=swapA;
}
}
return init->next;
}
};