一.题目
给一个链表,两两交换其中的节点,然后返回交换后的链表。
样例:给出 1->2->3->4, 你应该返回的链表是 2->1->4->3。
二.解题思路
定义一个头节点,头节点指向第一个节点,先将前两个节点交换,再让头结点指向交换后的第一个节点,然后将头节点移到交换后的第二个节点,重复刚才的交换步骤,依次往后进行直到最后两个元素.
三.实现代码
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
/**
* @param head a ListNode
* @return a ListNode
*/
ListNode* swapPairs(ListNode* head) {
// Write your code here
if(head ==NULL|| head->next ==NULL)
return head;
ListNode *p = new ListNode(0);
p->next = head;
ListNode *r = p;
while(p->next != NULL &&p->next->next != NULL){
ListNode *a =p->next;
ListNode *b = p->next->next;
a->next =b->next;
b->next =a;
p->next =b;
p= p->next->next;
}
return r->next;
}
};
四.感想
巧妙地利用头节点,两个两个的元素进行交换.