21. 合并两个有序链表

简介: 21. 合并两个有序链表

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

需要注意的是空节点的处理。

1.暴力

    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
       ListNode dummy = new ListNode(-1);
       ListNode prev = dummy;
       while (l1 != null && l2 != null) {
           if (l1.val <l2.val ) {
               prev.next = l1;
               l1 = l1.next;
           } else {
               prev.next = l2;
               l2 = l2.next;
           }
           prev = prev.next;
       }
       prev.next = l1==null? l2 : l1;
       return dummy.next;
    }

2.递归

    public ListNode mergeTwoLists(ListNode l1, 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;
        }
    }
相关文章
|
1月前
|
算法
LeetCode刷题---21.合并两个有序链表(双指针)
LeetCode刷题---21.合并两个有序链表(双指针)
LeetCode | 21. 合并两个有序链表
LeetCode | 21. 合并两个有序链表
|
5天前
|
算法 Java
[Java·算法·中等] LeetCode21. 合并两个有序链表
[Java·算法·中等] LeetCode21. 合并两个有序链表
13 2
|
17天前
|
算法 安全 Java
【经典算法】LeetCode 21:合并两个有序链表Java/C/Python3实现含注释说明,Easy)
【经典算法】LeetCode 21:合并两个有序链表Java/C/Python3实现含注释说明,Easy)
15 1
|
1月前
21. 合并两个有序链表
21. 合并两个有序链表
33 4
|
1月前
|
存储 算法
头歌:第1关:有序单链表的插入操作
头歌:第1关:有序单链表的插入操作
177 0
|
13天前
|
SQL 算法 数据挖掘
LeetCode 二十一:合并两个有序链表 【python】
LeetCode 二十一:合并两个有序链表 【python】
|
25天前
题目----力扣--合并两个有序链表
题目----力扣--合并两个有序链表
18 0
|
27天前
|
索引
【力扣刷题】回文链表、环形链表、合并两个有序链表
【力扣刷题】回文链表、环形链表、合并两个有序链表
20 0
|
1月前
【力扣】21. 合并两个有序链表
【力扣】21. 合并两个有序链表