23. Merge k Sorted Lists

瘦欲@ 提交于 2019-12-01 10:26:31

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直接复用归并排序即可
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* mergeKLists(vector<ListNode*>& lists) {
        ListNode *res=NULL;
        for(int i=0;i<lists.size();++i)
        {
            if(NULL==res)
            {
                res=lists[i];
                continue;
            }
            res=merge(res,lists[i]);
        }
        return res;
    }
    
    ListNode* merge(ListNode *l1,ListNode *l2) {
        if(NULL==l1)return l2;
        if(NULL==l2)return l1;
        if(l1->val<l2->val)
        {
            l1->next=merge(l1->next,l2);
            return l1;
        }
        
        l2->next=merge(l1,l2->next);
        return l2;
    }
};

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!