//给你一个链表数组,每个链表都已经按升序排列。 
//
// 请你将所有链表合并到一个升序链表中,返回合并后的链表。 
//
// 
//
// 示例 1: 
//
// 输入:lists = [[1,4,5],[1,3,4],[2,6]]
//输出:[1,1,2,3,4,4,5,6]
//解释:链表数组如下:
//[
//  1->4->5,
//  1->3->4,
//  2->6
//]
//将它们合并到一个有序链表中得到。
//1->1->2->3->4->4->5->6
// 
//
// 示例 2: 
//
// 输入:lists = []
//输出:[]
// 
//
// 示例 3: 
//
// 输入:lists = [[]]
//输出:[]
// 
//
// 
//
// 提示: 
//
// 
// k == lists.length 
// 0 <= k <= 10^4 
// 0 <= lists[i].length <= 500 
// -10^4 <= lists[i][j] <= 10^4 
// lists[i] 按 升序 排列 
// lists[i].length 的总和不超过 10^4 
// 
// Related Topics 堆 链表 分治算法 
// 👍 1148 👎 0

/*
* 23 合并K个升序链表
* 2021-02-22 17:18:56
* @author oxygenbytes
*/ 
#include "leetcode.h" 
//leetcode submit region begin(Prohibit modification and deletion)
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    struct cmp{
        bool operator() (ListNode* a, ListNode* b){
            return a->val > b->val;
        }
    };
    ListNode* mergeKLists(vector<ListNode*>& lists) {
        if(lists.size() == 0) return nullptr;
        if(lists.size() == 1) return lists[0];
        priority_queue<ListNode*, vector<ListNode*>, cmp> pq;

        for(int i = 0;i < lists.size();i++){
            auto t = lists[i];
            if(t) pq.push(t);
        }

        ListNode dummy(-1);
        auto ptr = &dummy;

        while(pq.size()){
            auto t = pq.top();
            pq.pop();
            if(t->next) pq.push(t->next);
            ptr->next = t;
            ptr = ptr->next;
        }

        return dummy.next;
    }
};
//leetcode submit region end(Prohibit modification and deletion)