关于java:25-合并两个排序的链表双指针递归

25. 合并两个排序的链表

思路一:指针程序遍历

头节点未知,就新建一个头指针,ListNode list = new ListNode(0);
谁小,head的next指针就指向谁
直到某一个链表空了,就让head接上另一个链表的残余;
操作:

思路二:递归

终止条件:l1 l2其中一个为空时,返回另一个;
留神!!其中一个为空的反两个都不为空

(l1!=null)&&(l2!=null)

递归主体

l1 = marge(l1.next,l2);
或
l2 = marge(l1,l2.next);

上面以

l1 = [1,3,5]
l2 = [1,2,8,9]

为例
递归进入,


操作:

    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(l1, l2.next);
            return l2;
        }
    }

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理