算法学习 -- 多路归并

思想 :

抽象出来一个例子 : 合并k个长度相等升序列表 :

抽象成一张表也就是 :

做法 : 用一个小根堆来维护 , 首先将每个序列的第一个元素放入队列中 , 然后模拟,每次取出队头,作为结果序列的下一个元素 , 然后向堆中存入该元素序列中的下一个元素 ,直到所有元素取完为止;

例题 :

1262 - 鱼塘钓鱼

1262. 鱼塘钓鱼 - AcWing题库

c++代码 :

复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N = 110 ;
typedef pair<int, int> PII;
int a[N] , b[N] , c[N] ;
int n , T ;

int main(){
    cin >> n ; 
    for(int i=1;i<=n;i++) cin >> a[i] ;
    for(int j=1;j<=n;j++) cin >> b[j] ;
    for(int k=2;k<=n;k++) cin >> c[k] , c[k] += c[k-1] ;
    cin >> T ;
    int ans = 0 ;
    // 只在前k个池塘钓鱼
    for(int i=1;i<=n;i++){
        int t = T - c[i] ; // 本次钓鱼专用时间 
        priority_queue<PII> que ;
        for(int j=1;j<=i;j++) que.push({a[j],j}) ;
        int res = 0 ;
        while(!que.empty() && t > 0){
            auto it = que.top() ; que.pop() ;
            int x = it.first , idx = it.second ; // 获取元素和下标
            res += x ;
            int xx = x - b[idx] ;
            if(xx > 0) que.push({xx , idx}) ;
            t -- ;
        }
        ans = max(ans , res) ;
    }
    cout << ans << endl ;
}

62 . 丑数

62. 丑数 - AcWing题库

复制代码
class Solution {
public:
    int getUglyNumber(int n) {
        if(n <= 1) return n;
        vector<int> f(1,1);
        int i = 0, j = 0, k = 0;
        long long t = 0;
        while(--n)
        {
            t = min(f[i] * 2, min (f[j] * 3, f[k] * 5));
            if(t == f[i] * 2) i++;
            if(t == f[j] * 3) j++;
            if(t == f[k] * 5) k++;
            f.push_back(t);
        }
        return f.back();
    }
};

参考 : 多路归并算法从理论到应用(易懂)-CSDN博客

相关推荐
西岸行者3 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习
悠哉悠哉愿意3 天前
【单片机学习笔记】串口、超声波、NE555的同时使用
笔记·单片机·学习
别催小唐敲代码3 天前
嵌入式学习路线
学习
毛小茛3 天前
计算机系统概论——校验码
学习
babe小鑫3 天前
大专经济信息管理专业学习数据分析的必要性
学习·数据挖掘·数据分析
winfreedoms3 天前
ROS2知识大白话
笔记·学习·ros2
在这habit之下3 天前
Linux Virtual Server(LVS)学习总结
linux·学习·lvs
我想我不够好。3 天前
2026.2.25监控学习
学习
im_AMBER3 天前
Leetcode 127 删除有序数组中的重复项 | 删除有序数组中的重复项 II
数据结构·学习·算法·leetcode
CodeJourney_J3 天前
从“Hello World“ 开始 C++
c语言·c++·学习