leetcode #24 两两交换链表中的节点(C++)递归

题目:给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。

注意:你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

 

示例:

给定 1->2->3->4, 你应该返回 2->1->4->3.

一直都不会写递归,可能是没有那个脑子呜呜呜。今天强行写了一下。

 

递归版本:

class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        if(head == NULL || head->next == NULL)  return head; //终止条件
        ListNode* node = head->next; 
        head->next = swapPairs(head->next->next);
        node->next = head;
        return node;
    }
};

 

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/swap-nodes-in-pairs
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

 

你可能感兴趣的:(链表)