【剑斩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;
    }
};
相关推荐
永远都不秃头的程序员(互关)15 小时前
【决策树深度探索(一)】从零搭建:机器学习的“智慧之树”——决策树分类算法!
算法·决策树·机器学习
程序员-King.15 小时前
day161—动态规划—最长递增子序列(LeetCode-300)
算法·leetcode·深度优先·动态规划·递归
西柚小萌新15 小时前
【计算机视觉CV:目标检测】--3.算法原理(SPPNet、Fast R-CNN、Faster R-CNN)
算法·目标检测·计算机视觉
高频交易dragon15 小时前
Hawkes LOB Market从论文到生产
人工智能·算法·金融
_OP_CHEN15 小时前
【算法基础篇】(五十)扩展中国剩余定理(EXCRT)深度精讲:突破模数互质限制
c++·算法·蓝桥杯·数论·同余方程·扩展欧几里得算法·acm/icpc
福楠15 小时前
C++ STL | set、multiset
c语言·开发语言·数据结构·c++·算法
enfpZZ小狗15 小时前
基于C++的反射机制探索
开发语言·c++·算法
炽烈小老头15 小时前
【每天学习一点算法 2026/01/22】杨辉三角
学习·算法
MicroTech202515 小时前
微算法科技(NASDAQ :MLGO)量子安全区块链:PQ-DPoL与Falcon签名的双重防御体系
科技·算法·安全
努力也学不会java15 小时前
【Spring Cloud】 服务注册/服务发现
人工智能·后端·算法·spring·spring cloud·容器·服务发现