合并K个升序链表

题目
解法一

优先级队列

思想

将每个链表中的一个节点存放到优先级队列中,本题采用小根堆,将小根堆中的根节点取出,插入到最终的链表中,并且将该节点在原链表中的下一个节点插入小根堆中(需要向下调整),直到堆中没有节点为止(即所以链表都已经合并完)。

代码
cpp 复制代码
class Solution {
public:
    struct Less{
        bool operator()(ListNode* l1,ListNode* l2){
            return l1->val > l2->val;
        }
    };

    ListNode* mergeKLists(vector<ListNode*>& lists) {
        ListNode* node=new ListNode(0);
        ListNode* cur=node;
        priority_queue<ListNode*,vector<ListNode*>,Less> q;
        for(auto& it:lists){
            if(it) q.push(it);
        }
        while(!q.empty()){
            ListNode* tmp=q.top();
            q.pop();
            cur->next=tmp;
            if(tmp->next) q.push(tmp->next);
            cur=cur->next;
        }
        return node->next;
    }
};
解法二

归并/分治

思想

将链表两两进行合并,直到合并为一个链表为止。

代码
cpp 复制代码
class Solution {
public:
    ListNode* mergeKLists(vector<ListNode*>& lists) {
        return mergeL(lists,0,lists.size()-1);
    }

    ListNode* mergeL(vector<ListNode*>& lists,int l,int r){
        if(l>r) return nullptr;
        if(l==r) return lists[l];
        int mid=(l+r)>>1;
        ListNode* l1=mergeL(lists,l,mid);
        ListNode* l2=mergeL(lists,mid+1,r);
        return merge2L(l1,l2);
    }

    ListNode* merge2L(ListNode* l1,ListNode* l2){
        if(l1==nullptr) return l2;
        if(l2==nullptr) return l1;
        if(l1->val < l2->val){
            l1->next=merge2L(l1->next,l2);
            return l1;
        }
        else{
            l2->next=merge2L(l1,l2->next);
            return l2;
        }
    }
};
相关推荐
学习使我变快乐1 小时前
C++:用类实现链表,队列,栈
开发语言·c++·链表
马剑威(威哥爱编程)1 小时前
除了递归算法,要如何优化实现文件搜索功能
java·开发语言·算法·递归算法·威哥爱编程·memoization
算法萌新——12 小时前
洛谷P2240——贪心算法
算法·贪心算法
湖北二师的咸鱼2 小时前
专题:二叉树递归遍历
算法·深度优先
重生之我要进大厂2 小时前
LeetCode 876
java·开发语言·数据结构·算法·leetcode
Happy鱿鱼3 小时前
C语言-数据结构 有向图拓扑排序TopologicalSort(邻接表存储)
c语言·开发语言·数据结构
KBDYD10103 小时前
C语言--结构体变量和数组的定义、初始化、赋值
c语言·开发语言·数据结构·算法
Crossoads3 小时前
【数据结构】排序算法---桶排序
c语言·开发语言·数据结构·算法·排序算法
自身就是太阳3 小时前
2024蓝桥杯省B好题分析
算法·职场和发展·蓝桥杯
孙小二写代码4 小时前
[leetcode刷题]面试经典150题之1合并两个有序数组(简单)
算法·leetcode·面试