目的
旨在记录在Leedcode网上刷题的过程,记录心得。
题目
输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。
示例1:
输入:1->2->4, 1->3->4
输出:1->1->2->3->4->4
限制:
0 <= 链表长度 <= 1000
思路:
思路1:将2个链表的数据取出来,排好序,重新创建新的链表,返回
这个思路与此前的文章Leedcode编程题23: 合并K个排序链表----C++实现类似,代码略。
思路2:使用伪头结点
时间复杂度:o(m+n),m、n分别是l1和l2的长度
空间复杂度:o(1)
代码:
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
/*
思路2:使用伪头结点
时间复杂度:o(m+n),m、n分别是l1和l2的长度
空间复杂度:o(1)
*/
ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
ListNode dum = ListNode(0);
ListNode* cur = &dum;
while(l1 && l2) {
if(l1->val < l2->val) {
cur->next = l1;
l1 = l1->next;
}
else {
cur->next = l2;
l2 = l2->next;
}
cur = cur->next;
}
cur->next = l1? l1 : l2;
return dum.next;
}
};
效果: