[LeetCode]21. 合并两个有序链表(递归)

题目

将两个有序链表合并为一个新的有序链表并返回。新链表是经过拼接给定的两个链表的全部节点组成的。 网络

示例:code

输入:1->2->4, 1->3->4
输出:1->1->2->3->4->4排序

来源:力扣(LeetCode)
连接:https://leetcode-cn.com/problems/merge-two-sorted-lists
著做权归领扣网络全部。商业转载请联系官方受权,非商业转载请注明出处。递归

题解(转)

递归三要素:leetcode

  • 终止条件:两条链表分别名为 l1 和 l2,当 l1 为空或 l2 为空时结束
  • 返回值:每一层调用都返回排序好的链表头
  • 本级递归内容:若是 l1 的 val 值更小,则将 l1.next 与排序好的链表头相接,l2 同理

很好的图解参考连接:https://leetcode-cn.com/problems/merge-two-sorted-lists/solution/hua-jie-suan-fa-21-he-bing-liang-ge-you-xu-lian-bi/get

代码

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
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;
        }
    }
}
相关文章
相关标签/搜索