贪心:Huffman树

合并果子:

该题与石子合并的区别:石子合并是两两相邻才能合并,这题是任意两点合并

该题的思路:每次合并最小的两个点

cpp 复制代码
#include <iostream>
#include <algorithm>
#include <queue>

using namespace std;

int main()
{
    int n;
    scanf("%d", &n);

    priority_queue<int, vector<int>, greater<int>> heap;//小根堆,所以堆头是最小值
    while (n -- )
    {
        int x;
        scanf("%d", &x);
        heap.push(x);
    }

    int res = 0;//答案
    while (heap.size() > 1)//只要超过两个数,就两个合并。因为是小根堆,每次合并的都是最小的两个
    {
        int a = heap.top(); heap.pop();
        int b = heap.top(); heap.pop();
        res += a + b;
        heap.push(a + b);
    }

    printf("%d\n", res);
    return 0;
}
相关推荐
坚果派·白晓明12 小时前
[鸿蒙PC三方库移植适配] 使用 AtomCode + Skills 自动完成libhv鸿蒙化适配
c++·华为·ai编程·harmonyos·atomcode
AZaLEan__12 小时前
图论:拓扑排序
算法·深度优先
悠仁さん12 小时前
数据结构 排序
数据结构·算法·排序算法
2301_7890156212 小时前
Linux基础开发工具一:软件包管理器、vim编辑器
linux·服务器·c语言·汇编·c++·编辑器·vim
阿文的代码库12 小时前
机器学习之精确率和召回率的关系
人工智能·算法·机器学习
玖玥拾12 小时前
C/C++ 基础笔记(十)
c语言·c++
Frank学习路上12 小时前
【C++】面试:指针与引用
c++·面试
咸鱼翻身小阿橙12 小时前
高斯模糊降噪/磨皮算法降噪图像
前端·opencv·算法·webpack·c#
YIN_尹12 小时前
【Linux系统编程】基础IO第一讲——系统文件IO
android·java·linux·c++
代码中介商12 小时前
数据结构进阶(五):最短路径——Dijkstra 与 Floyd 算法
数据结构·算法