码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【ACWing】3531. 哈夫曼树


    题目地址:

    https://www.acwing.com/problem/content/description/3534/

    给定 N N N个权值作为 N N N个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。现在,给定 N N N个叶子结点的信息,请你构造哈夫曼树,并输出该树的带权路径长度。
    相关知识:
    1、路径和路径长度:
    在一棵树中,从一个结点往下可以达到的孩子或孙子结点之间的通路,称为路径。通路中分支的数目称为路径长度。若规定根结点的层数为 1 1 1,则从根结点到第 L L L层结点的路径长度为 L − 1 L−1 L−1。
    2、结点的权及带权路径长度:
    若将树中结点赋给一个有着某种含义的数值,则这个数值称为该结点的权。结点的带权路径长度为:从根结点到该结点之间的路径长度与该结点的权的乘积。
    3、树的带权路径长度:
    树的带权路径长度规定为所有叶子结点的带权路径长度之和,记为WPL。

    输入格式:
    第一行包含整数 N N N,表示叶子结点数量。
    第二行包含 N N N个整数,表示每个叶子结点的权值。

    输出格式:
    输出一个整数,表示生成哈夫曼树的带权路径长度。

    数据范围:
    2 ≤ N ≤ 1000 2≤N≤1000 2≤N≤1000
    叶子结点的权值范围 [ 1 , 100 ] [1,100] [1,100]

    最小堆,参考https://blog.csdn.net/qq_46105170/article/details/113750503。代码如下:

    #include 
    #include 
    using namespace std;
    
    const int N = 1010;
    int n, res;
    priority_queue<int, vector<int>, greater<int>> heap;
    
    int main() {
      scanf("%d", &n);
      for (int i = 1; i <= n; i++) {
        int x;
        scanf("%d", &x);
        heap.push(x);
      }
      
      while (heap.size() >= 2) {
        int x = heap.top(); heap.pop();
        int y = heap.top(); heap.pop();
        res += x + y;
        heap.push(x + y);
      }
    
      printf("%d\n", res);
    }
    

    时间复杂度 O ( n log ⁡ n ) O(n\log n) O(nlogn),空间 O ( n ) O(n) O(n)。

  • 相关阅读:
    2022年9月8号Java23设计模式学习(课时三)抽象工厂模式
    操作系统中的进程是什么?(详细讲解进程调度相关PCB信息)
    有哪些公共管理或行政管理学习帮助较大的外文期刊?
    Python 全栈系列232 再次搭建RabbitMQ
    26栈和队列-简单实践
    从JSON1链中学习处理JACKSON链的不稳定性3
    AutoGCL:基于可学习视图生成器的自动图对比学习
    【无标题】
    未来,属于终身学习者
    程序开发中表示密码时使用 password 还是 passcode?
  • 原文地址:https://blog.csdn.net/qq_46105170/article/details/127046364
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号