题目
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
示例 :
输入:l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]
思路
-
创建一个新的链表头节点(dummyNode)和一个指针current,用于表示当前节点。
-
在一个while循环中,比较两个链表的节点值,并依次将较小值的节点连接到新链表上。具体的步骤如下:
- 如果list1的节点值小于等于list2的节点值,那么将current的next指针指向list1,并将list1指针后移一位。
- 否则,将current的next指针指向list2,并将list2指针后移一位。
- 然后,将current指针后移一位。
-
当循环结束时,说明至少有一个链表已经遍历完毕。我们需要将剩余未遍历完的链表连接到新链表的末尾。具体的步骤如下:
- 如果list1还有剩余节点,将current的next指针指向list1。
- 如果list2还有剩余节点,将current的next指针指向list2。
-
最后,返回dummyNode的next指针,即为合并后的新链表的头节点。
通过以上步骤,我们可以将两个升序链表合并为一个新的升序链表。该算法的时间复杂度为O(m+n),其中m和n分别为两个链表的长度。
Code:
class Solution {
public:
ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
// 创建一个新的链表头节点
ListNode dummyNode(0);
ListNode* current = &dummyNode;
// 比较两个链表的节点值,依次将较小值的节点连接到新链表上
while (list1 && list2) {
if (list1->val <= list2->val) {
current->next = list1;
list1 = list1->next;
} else {
current->next = list2;
list2 = list2->next;
}
current = current->next;
}
// 将剩余未遍历完的链表连接到新链表上
if (list1) {
current->next = list1;
}
if (list2) {
current->next = list2;
}
return dummyNode.next; // 返回新链表的头节点
}
};