算法学习-合并两个有序链表

本文探讨了如何合并两个已排序的链表,通过比较节点值来创建新的有序链表。提供的Java代码展示了递归解决方案,首先检查其中一个链表是否为空,然后通过比较节点值决定合并的顺序。这个过程涉及到了链表操作和排序算法的基础知识。

今天又是做题的一天

我觉得我得先好好学一下算法,再做题了 好难 

 

    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        if (l1 == null) return l2; //要是空的 就是直接用l2的链表
        if (l2 == null) return l1;
        ListNode res = l1.val < l2.val ? l1 : l2; 
        res.next = mergeTwoLists(res.next, l1.val >= l2.val ? l1 : l2);
        return res;
    }

 

 * public class ListNode {
 *     int val; 当前节点值
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }

 

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值