美文网首页
[LeetCode](week2) 23. Merge k So

[LeetCode](week2) 23. Merge k So

作者: jeff98 | 来源:发表于2018-09-16 12:02 被阅读0次

这周课是讲分治法,那就来做一题分治类型的Hard题目

题目描述

Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity.

Example:

Input:

[
  1->4->5,
  1->3->4,
  2->6
]

Output:

1->1->2->3->4->4->5->6

题目分析

一开始除了砍半想过其他的砍法(比如三分),但用Master Theorem思考了一下发现复杂度是一样的:
T(n) = 3T(n/3) + O(n)
T(n) = 2T(n/2) + O(n)
复杂度都是 O(n^{log_{b}{a}}) = O(n)

错误分析

0

head 和 result

1

Input:
[[],[1]]
Output:
[]
Expected:
[1]

弱智错误

代码

#include <iostream>
#include <vector>

struct ListNode {
    int val;
    ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};

class Solution {
public:
    ListNode* mergeKLists(vector<ListNode*>& lists) {
        if(lists.size() == 0){
            return NULL;
        }
        else if(lists.size() == 1){
            return lists[0];
        }
        else if(lists.size() == 2){
            return mergeTwoLists(lists[0], lists[1]);
        }
        else if(lists.size() > 2){
            vector<ListNode*> temp1;
            int i;
            for(i = 0; i < lists.size()/2; ++i){
                temp1.push_back(lists[i]);
            }
            vector<ListNode*> temp2;
            for(i; i< lists.size(); ++i){
                temp2.push_back(lists[i]);
            }
            return mergeTwoLists(mergeKLists(temp1), mergeKLists(temp2));
        }

    }

    ListNode* mergeTwoLists(ListNode* a, ListNode* b){
        if(a == NULL)
            return a;
        else if(b == NULL)
            return b;
    
        ListNode *result;
        if(a->val < b->val){
            result = new ListNode(a->val);
            a = a->next;
        }
        else{
            result = new ListNode(b->val);
            b = b->next;
        }
        result->next = NULL;

        while(1){
            if(a == NULL){
                result->next = b;
                break;
            }
            else if(b == NULL){
                result->next = a;
                break;
            }
            else{
                if(a->val < b->val){
                    result->next = new ListNode(a->val);
                    result = result->next;
                    a = a->next;
                }
                else{
                    result->next = new ListNode(b->val);
                    result = result->next;
                    b = b->next;
                }
            }
        }
        return result;
    }
};

分析

https://leetcode.com/problems/merge-k-sorted-lists/solution/

相关文章

网友评论

      本文标题:[LeetCode](week2) 23. Merge k So

      本文链接:https://www.haomeiwen.com/subject/ahixnftx.html