码迷,mamicode.com
首页 > 其他好文 > 详细

Swap Nodes in Pairs ——解题报告

时间:2015-05-12 09:25:09      阅读:114      评论:0      收藏:0      [点我收藏+]

标签:leetcode   链表   递归   反转   


    【题目】

    Given a linked list, swap every two adjacent nodes and return its head.

For example,
Given 1->2->3->4, you should return the list as 2->1->4->3.

Your algorithm should use only constant space. You may not modify the values in the list, only nodes itself can be changed.


    【分析】

    使用递归解决,首先跳出递归的条件一定是链表剩余长度为0或1,即head == NULL,head->next == NULL. 其次,一定要注意在链表还有剩余节点的情况下倒转两个节点,不然,head->next都为空了,如何反转后面节点呢?具体见下面注释。


    【代码】

    运行时间4ms


/**
 * 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) {
        
        if(head == NULL || head->next == NULL)  // 递归跳出条件
            return head;
        ListNode* tmp = swapPairs(head->next->next);  //一定要在前面递归,如果head->next都为空了,递归进去是可以看到的,但是下面直接去head->next就判断不了。
        ListNode* res = head->next;
        res->next = head;
        res->next->next = tmp;
        return res;
    }
};


Swap Nodes in Pairs ——解题报告

标签:leetcode   链表   递归   反转   

原文地址:http://blog.csdn.net/puqutogether/article/details/45664495

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!