欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

21. 合并两个有序链表

程序员文章站 2022-07-14 14:34:46
...

21. 合并两个有序链表

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
思路:递归实现,新链表也不需要构造新节点,终止条件:两条链表分别名为 l1 和 l2,当 l1 为空或 l2 为空时结束,返回值:每一层调用都返回排序好的链表头,如果 l1 的 val 值更小,则将 l1.next 与排序好的链表头相接,l2 同理。

/**
 * Definition for singly-linked list.
 * 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; }
 * }
 */
class Solution {
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        //有序 递归
        if(l1 == null)
            return l2;
        if(l2 == null)
            return l1;
        
        if(l1.val < l2.val){
            l1.next = mergeTwoLists(l1.next, l2);
            return l1;
        }else{
            l2.next = mergeTwoLists(l2.next,l1);
            return l2;
        }
        
    }
}
相关标签: LeetCode Hot100