• 两两交换链表中的节点


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

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

     

    示例:

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

    方法一:

    递归

    递归写法要观察本级递归的解决过程,形成抽象模型,因为递归本质就是不断重复相同的事情。而不是去思考完整的调用栈,一级又一级,无从下手。如图所示,我们应该关注一级调用小单元的情况,也就是单个f(x)。

    其中我们应该关心的主要有三点:

        返回值
        调用单元做了什么
        终止条件

    在本题中:

        返回值:交换完成的子链表
        调用单元:设需要交换的两个点为 head 和 next,head 连接后面交换完成的子链表,next 连接 head,完成交换
        终止条件:head 为空指针或者 next 为空指针,也就是当前无节点或者只有一个节点,无法进行交换
    代码实现:

    struct ListNode* swapPairs(struct ListNode* head){
        if(head == NULL || head->next == NULL){
            return head;
        }
        struct ListNode * next=head->next;
        head->next=swapPairs(next->next);
        next->next=head;
        return  next;
    }

    方法二:

    非递归

    每次交换两个节点,直到遍历链表结束时无法交换。

    代码实现:

    struct ListNode* swapPairs(struct ListNode* head){
        struct  ListNode  * pre=malloc(sizeof(struct ListNode));
        pre->next=head;
        struct ListNode * temp=pre;
        while(temp->next !=NULL && temp->next->next){
            struct ListNode * start=temp->next;
            struct ListNode * end=start->next;
            temp->next=end;
            start->next=end->next;
            end->next=start;
            temp=start;
        }

        return pre->next;

    }



    作者:guanpengchn
    链接:https://leetcode-cn.com/problems/swap-nodes-in-pairs/solution/hua-jie-suan-fa-24-liang-liang-jiao-huan-lian-biao/
    来源:力扣(LeetCode)
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

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

  • 相关阅读:
    [C#]App.Config
    [转][JS]修改链接中的参数
    [转][Oracle]常见报错及处理
    [转]截图软件分享
    [转][C#]手写 Socket 服务端
    3.6的pprint写法改变了:pprint.pprint()
    版本优化-test
    python爬取豆瓣小组700+话题加回复啦啦啦python open file with a variable name
    爬豆瓣被封的解决方案
    去除列表中字符串中的空格换行等
  • 原文地址:https://www.cnblogs.com/pigdragon/p/12458880.html
Copyright © 2020-2023  润新知