一、题目描述
给定一个链表,交换他们相邻的两个数
Example:
Given1->2->3->4
you should return the list as2->1->4->3
二、思路
采用递归的方法求解
三、C代码
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* swapPairs(struct ListNode* head){
if(head == NULL || head->next == NULL)
return head;
struct ListNode *temp = head->next;
head->next = swapPairs(temp->next);
temp->next = head;
return temp;
}