贪心: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;
}
相关推荐
juleskk几秒前
2.18复试训练
算法
白太岁2 分钟前
Muduo:(0) 架构与接口总览
c++·架构·tcp
闻缺陷则喜何志丹5 分钟前
微分中值定理与导数的应用
c++·高等数学·微分·中值定理·导数应用
tankeven5 分钟前
HJ94 记票统计
c++·算法
逆境不可逃10 分钟前
LeetCode 热题 100 之 76.最小覆盖子串
java·算法·leetcode·职场和发展·滑动窗口
I_LPL16 分钟前
day35 代码随想录算法训练营 动态规划专题3
java·算法·动态规划·hot100·求职面试
DeepModel19 分钟前
【回归算法】多项式回归详解
算法·回归
雨翼轻尘20 分钟前
2.1 链表1
数据结构·链表
Frostnova丶37 分钟前
LeetCode 761. 特殊的二进制字符串
算法·leetcode
mjhcsp1 小时前
C++ 树形 DP解析
开发语言·c++·动态规划·代理模式