合并两个有序链表
# 📃 题目描述
题目链接:21. 合并两个有序链表 - 力扣(LeetCode) (leetcode-cn.com) (opens new window)
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
示例 1:
输入:l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]
示例 2:
输入:l1 = [], l2 = []
输出:[]
示例 3:
输入:l1 = [], l2 = [0]
输出:[0]
# 🔔 解题思路
简单题,新建一个链表,用来存储合并后的链表。
我们维护一个 ptr3
指针指向新链表的尾节点,我们需要做的是调整它的 next
指针。然后,我们重复以下过程,直到 l1 或者 l2 指向了 null :如果 l1 当前节点的值小于等于 l2 ,我们就把 l1 当前的节点接在 ptr3
节点的后面同时将 l1 指针往后移一位。否则,我们对 l2 做同样的操作。不管我们将哪一个元素接在了后面,我们都需要把 ptr3
向后移一位。
在循环终止的时候, l1 和 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 || l2 == null) {
return l1 == null ? l2 : l1;
}
// 新链表的头节点
ListNode l3 = new ListNode(0);
// 工作节点
ListNode ptr3 = l3;
while (l1 != null && l2 != null) {
if (l1.val < l2.val) {
ptr3.next = l1;
l1 = l1.next;
} else {
ptr3.next = l2;
l2 = l2.next;
}
ptr3 = ptr3.next;
}
// 在循环终止的时候, l1 和 l2 至多有一个是非空的
ptr3.next = (l1 == null) ? l2 : l1;
return l3.next;
}
}
# 💥 复杂度分析
- 空间复杂度:O(N)
- 时间复杂度:O(N)
🎁 公众号

各位小伙伴大家好呀,叫我小牛肉就行,目前在读东南大学硕士,上方扫码关注公众号「飞天小牛肉」,与你分享我的成长历程与技术感悟~
帮助小牛肉改善此页面 (opens new window)
Last Updated: 2023/02/16, 11:27:10