Leetcode 24 成对的交换链表节点 Swap Nodes in Pairs

第一种解法  非递归:

更新p和head的值

非递归的相关代码如下:

//非递归代码
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        if(!head || !head->next)   //不需要交换
            return head;
        ListNode* new_head = new ListNode(0);
        ListNode* p = new_head;
        
        while(head && head->next)
        {
            ListNode* next = head->next;
            ListNode* nnext = next->next;
            p->next = next;
            next->next = head;
            head->next = nnext;
            p = head;
            head = nnext;
        }
        return new_head->next;
    }
};

第二种解法  递归:

函数swapPairs(ListNode* head)返回的是以head为头结点的链表进行交换之后的头结点,递归函数的停止条件是以head开头的链表为空或者只有1个节点。

//递归解法
class Solution {
public:
    ListNode* swapPairs(ListNode* head) {
        if(!head || !head->next)   //不需要交换
            return head;
        
        ListNode* next = head->next;  //取head的下一个节点
        head->next = swapPairs(next->next);//将head和交换之后的头结点链接
        next->next = head;  //将原来第二个节点和head链接
        return next;
    }
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值