Skip to content
本页目录

0021-合并两个有序链表

https://leetcode.cn/problems/merge-two-sorted-lists

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

示例 1:

输入:l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]

示例 2:

输入:l1 = [], l2 = []
输出:[]

示例 3:

输入:l1 = [], l2 = [0]
输出:[0]

提示:

两个链表的节点数目范围是 [0, 50]
-100 <= Node.val <= 100
l1 和 l2 均按 非递减顺序 排列

思路:创建 dummyHead 直接按序合并

csharp
public class Solution {
    public ListNode MergeTwoLists(ListNode l1, ListNode l2) {
    	ListNode dummyHead = new ListNode();
    	ListNode cur = dummyHead;
    	while(l1 != null && l2 != null){
    		if(l1.val < l2.val){
    			cur.next = l1;
    			l1 = l1.next;
    		}
    		else{
    			cur.next = l2;
    			l2 = l2.next;
    		}
    		cur = cur.next;
    	}
    	if(l1 != null){
    		cur.next = l1;
    	}
    	if(l2 != null){
    		cur.next = l2;
    	}
    	return dummyHead.next;
    }
}

思路2: 【官方】递归

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

Released under the MIT License.