【leetcode-合并两个有序链表】

迭代法

java 复制代码
  public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        ListNode result = new ListNode(0);
        ListNode cur = result;
        while(list1!=null && list2!=null){ 
            //判断list1和list2的大小
            int val1 =list1.val;
            int val2 =list2.val;
            if(val1<val2){
                //取最小的
                ListNode node = new ListNode(val1);
                cur.next=node;
                cur=cur.next;
                list1=list1.next;
            }else if(val1> val2){
                ListNode node = new ListNode(val2);
                cur.next=node;
                cur=cur.next;
                list2=list2.next;
            }else{
                ListNode node1 = new ListNode(val1);
                ListNode node2 = new ListNode(val2);
                cur.next=node1;
                cur=cur.next;
                cur.next=node2;
                cur=cur.next;
                list1=list1.next;
                list2=list2.next;
            }
        }
        //如果list1还有,则直接将list1插入到后面
        while(list1 !=null){
            cur.next=list1;
            cur=cur.next;
            list1=list1.next;
        }
        //同理list2
        while(list2!=null){
            cur.next=list2;
            cur=cur.next;
            list2=list2.next;
        }
        return result.next;
    }

递归法

java 复制代码
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        if(l1 == null || l2 == null){
            return l1==null ? l2 : l1;
        }
        if(l1.val <=l2.val){
            l1.next=mergeTwoLists(l1.next,l2);
            return l1;
        }else{
            l2.next=mergeTwoLists(l1,l2.next);
            return l2;
        }
    }
相关推荐
o0向阳而生0o8 分钟前
69、JS中如何调用上位机接口
javascript·上位机
白总Server36 分钟前
Golang dig框架与GraphQL的完美结合
java·大数据·前端·javascript·后端·go·graphql
m0_6799272043 分钟前
练习小项目11:鼠标跟随小圆点
前端·javascript·css·html
BillKu1 小时前
Vue3 + TypeScript 操作第三方库(Element Plus 的 ElTable)的内部属性
前端·javascript·typescript
Once_day2 小时前
代码训练LeetCode(33)字符串首次匹配
算法·leetcode·c
ice852 小时前
揭秘JavaScript中“一切皆对象”:包装对象机制和原型链继承
javascript·面试
谢尔登2 小时前
【Three.js】初识 Three.js
开发语言·javascript·ecmascript
Dream耀2 小时前
解锁JavaScript函数式编程的核心技能
前端·javascript·设计模式
小白luffy2 小时前
TypeScript枚举与常量枚举:从编译原理到最佳实践
前端·javascript
Jackson__2 小时前
谈谈 js 小数加法精度问题
前端·javascript·面试