题目:
Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists.
1 2 3 4
| Example:
Input: 1->2->4, 1->3->4 Output: 1->1->2->3->4->4
|
第一种解题方法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
|
class Solution { public: ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) { if(!l1 || !l2) return l1 ? l1 : l2;
if(l1->val < l2->val){ l1->next = mergeTwoLists(l1->next, l2); return l1; }else{ l2->next = mergeTwoLists(l1, l2->next); return l2; } } };
|
Status | Runtime | Language |
---|
Accepted | 8ms | cpp |
Time complexity
- T(n) = 1 + T(n-1)
- T(n) = O(n)
时间复杂度为O(n)
第二种解题方法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
class Solution { public: ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) { ListNode tmp(0); ListNode* tail=&tmp; while(l1 && l2){ if(l1->val < l2->val){ tail->next=l1; l1=l1->next; }else{ tail->next=l2; l2=l2->next; } tail=tail->next; } if(l1) tail->next=l1; if(l2) tail->next=l2; return tmp.next; } };
|
Status | Runtime | Language |
---|
Accepted | 13ms | cpp |
Time complexity
- T(n) = n + T(n-1)
- T(n) = O(n2)
时间复杂度为O(n2)