leetcode:21. 合并两个有序链表
题目
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
示例:![[简单] 21. 合并两个有序链表 - 图1](/uploads/projects/liangduo-rjrcs@ggu4wq/429c88f6e043d0c5835d22d35c969aec.jpeg)
输入:l1 = [1,2,4], l2 = [1,3,4]输出:[1,1,2,3,4,4]
输入:l1 = [], l2 = []输出:[]
输入:l1 = [], l2 = [0]输出:[0]
解答 & 代码
/*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* ListNode(int x) : val(x), next(nullptr) {}* ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/class Solution {public:ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {if(l1== nullptr && l2 == nullptr)return nullptr;ListNode* dummyHead = new ListNode(); // 虚拟头节点ListNode* pre = dummyHead; // 指向(合并后)新链表的尾节点ListNode* cur1 = l1; // 指向 l1 链表当前节点的指针ListNode* cur2 = l2; // 指向 l2 链表当前节点的指针// 使用 cur1、cur2 双指针同时遍历两个链表,将两者中值较小的节点插入新链表的尾部while(cur1 != nullptr && cur2 != nullptr){if(cur1->val <= cur2->val){pre->next = cur1;cur1 = cur1->next;}else{pre->next = cur2;cur2 = cur2->next;}pre = pre->next;}// 最后如果 l1 链表还没遍历完,直接将剩余部分接到新链表尾部if(cur1 != nullptr)pre->next = cur1;// 最后如果 l2 链表还没遍历完,直接将剩余部分接到新链表尾部else if(cur2 != nullptr)pre->next = cur2;return dummyHead->next;}};
复杂度分析:设两个链表长度分别为 m、n
- 时间复杂度 O(m + n)
- 空间复杂度 O(1)
执行结果:
执行结果:通过执行用时:12 ms, 在所有 C++ 提交中击败了 13.54% 的用户内存消耗:14.5 MB, 在所有 C++ 提交中击败了 21.95% 的用户
