zoukankan      html  css  js  c++  java
  • 合并两个有序链表

    将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

    示例:

    输入:1->2->4, 1->3->4
    输出:1->1->2->3->4->4

    方法一:

    思路: 递归法来合并连个有序的链表可以按照如下定义来执行:

    if(list1[0]->val < list2[0]->val ){

      list1[0] +merge(list1[1:], list2) 

    }else {

      list2[0] +merge(list1, list2[1:])

    }

    也就是说,两个链表头部较小的一个与剩下元素的 merge 操作结果合并。

    算法:

    我们直接将以上递归过程建模,首先考虑边界情况。
    特殊的,如果 l1 或者 l2 一开始就是 null ,那么没有任何操作需要合并,所以我们只需要返回非空链表。否则,我们要判断 l1 和 l2 哪一个的头元素更小,然后递归地决定下一个添加到结果里的值。如果两个链表都是空的,那么过程终止,所以递归过程最终一定会终止。

    代码实现:

    struct ListNode* mergeTwoLists(struct ListNode* l1, struct ListNode* l2){
                if(l1 ==NULL){
                    return l2;
                }else if(l2 == NULL){
                    return l1;
                }else if(l1->val < l2->val){
                    l1->next=mergeTwoLists(l1->next, l2);
                    return l1;
                }else{
                    l2->next=mergeTwoLists(l1, l2->next);
                    return l2; 
                }
    }



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

  • 相关阅读:
    钢铁雄心4陆战攻略
    装甲军团1跳出问题
    Git:解决报错:fatal: The remote end hung up unexpectedly
    保存网页到zotero研究
    面向服务软件工程
    华为matebook x pro监听耳机电流声
    战争游戏红龙修改手册
    manjaro20安装teamviewer出现sudo teamviewer –daemon start无响应
    manjaro20WPS缺少字体
    manjora20不小心卸载,重新安装terminal,软件商店/软件中心linux类似
  • 原文地址:https://www.cnblogs.com/pigdragon/p/12452122.html
Copyright © 2011-2022 走看看