【剑斩OFFER】算法的暴力美学——合并 k 个升序链表

一、题目描述

二、算法原理

思路:最小堆

1)首先弄出这样的堆,这个堆里面的结点保存的是每个链表的地址

2)每次拿出堆顶的结点,这个结点就是这么多个链表里面里面的最小值的结点

3)把堆顶的元素出堆

4)如果这个拿出堆顶的结点还有下一个结点,也就是说这个结点的下一个结点不为 nullptr ,则再把这个结点的下一个结点入堆。

5)重复上面的操作,直到这个堆为空

三、代码实现

cpp 复制代码
/**
 * 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) {}
 * };
 */
struct CampareNode//自定义最小堆的比较函数
{
    bool operator()(ListNode* x,ListNode* y)
    {
        return x->val > y->val;
    }
};

class Solution {
public:
    ListNode* mergeKLists(vector<ListNode*>& lists) {
        //初始化最小堆
        priority_queue<ListNode*,vector<ListNode*>,CampareNode> minheap;
        //把所有链表入堆
        for(auto& e : lists) if(e) minheap.push(e);
        //自定义一个链表
        ListNode* head = new ListNode(0);//哨兵结点
        ListNode* cur = head;
        while(minheap.size())
        {
            ListNode* tmp = minheap.top();//获取堆顶元素
            minheap.pop();//出堆
            cur->next = tmp;
            cur = tmp;
            if(tmp->next) minheap.push(tmp->next);
        }
        cur->next = nullptr;
        ListNode* result = head->next;
        delete head;//释放哨兵结点
        return result;
    }
};
相关推荐
智者知已应修善业4 分钟前
【51单片机用两个定时计数器级联实现定时】2023-04-12
c语言·经验分享·笔记·算法·51单片机
君义_noip5 分钟前
信息学奥赛一本通 1613:打印文章
c++·算法·信息学奥赛·csp-s
nglff12 分钟前
蓝桥杯抱佛脚第四天|前缀和,差分对应练习
算法·职场和发展·蓝桥杯
freexyn29 分钟前
Matlab入门自学七十四:坐标系转换,直角坐标、极坐标和球坐标的转换
开发语言·算法·matlab
咱就是说不配啊36 分钟前
3.20打卡day34
数据结构·c++·算法
小张会进步41 分钟前
数组:二维数组
java·javascript·算法
佑白雪乐1 小时前
LCR 175. 计算二叉树的深度
算法·深度优先
阿Y加油吧1 小时前
力扣打卡day07——最大子数组和、合并区间
算法
想吃火锅10051 小时前
【leetcode】105. 从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
圣保罗的大教堂1 小时前
leetcode 3567. 子矩阵的最小绝对差 中等
leetcode