当前位置:网站首页>Acwing:哈夫曼树(详解)
Acwing:哈夫曼树(详解)
2022-08-02 03:28:00 【正在黑化的KS】
题目描述:
给定 N 个权值作为 N 个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。
现在,给定 N 个叶子结点的信息,请你构造哈夫曼树,并输出该树的带权路径长度。
相关知识:
1、路径和路径长度
在一棵树中,从一个结点往下可以达到的孩子或孙子结点之间的通路,称为路径。通路中分支的数目称为路径长度。若规定根结点的层数为 1,则从根结点到第 L 层结点的路径长度为 L−1。
2、结点的权及带权路径长度
若将树中结点赋给一个有着某种含义的数值,则这个数值称为该结点的权。结点的带权路径长度为:从根结点到该结点之间的路径长度与该结点的权的乘积。
3、树的带权路径长度
树的带权路径长度规定为所有叶子结点的带权路径长度之和,记为 WPL。
输入格式
第一行包含整数 N,表示叶子结点数量。
第二行包含 N 个整数,表示每个叶子结点的权值。
输出格式
输出一个整数,表示生成哈夫曼树的带权路径长度。
数据范围
2≤N≤1000
叶子结点的权值范围 [1,100]。
输入样例:
5
1 2 2 5 9
输出样例:
37题目分析:
本质是一道哈夫曼树概念模版题!
首先我们一定要知道什么是哈夫曼树 这里给出哈夫曼树的定义。
这里的WPL也就是题目要求的结果
在本题中 给出了所有这颗二叉树的叶子结点 我们要做的就是用这些叶子结点构造出WPL最小的二叉树 即为哈夫曼树
显而易见的是 构造出一棵二叉树的方法是不唯一的 如下图例子
所以 应该根据什么来构造哈夫曼树呢?观察上图发现 第一种构造方法中 权值较大的节点更加靠近根结点 这也就是哈夫曼树构造的准则 即:
所以总结来看 构造一颗哈夫曼树的步骤如下:
哈夫曼树的两个重要性质:
1. 带权路径长度之和WPL = 所有非叶子结点的权值之和
如下图所示:
以 [5, 29, 7, 8, 14, 23, 3, 11] 为叶子结点构造出的哈夫曼树的WPL应该等于:
8 + 19 + 42 + 100 + 58 + 29 + 15 = 271
各位可以用WPL的计算公式验算一下。
2. 哈夫曼树的总节点数 = 2 * 叶子结点数 - 1
回归本题:
其实看到这里 这道题的做法已经很清晰了
首先将所有叶子结点放在一个堆中
我们只需要每次取出最小的两个节点 将他们的权值相加后放回堆中 同时累加答案(相加之后的权值之和)直到堆内只剩下最后一个点 即为根结点。
AC代码:
import heapq
N = int(input())
lst = list(map(int,input().split()))
heapq.heapify(lst)
res = 0
while len(lst) > 1 :
a = heapq.heappop(lst)
b = heapq.heappop(lst)
heapq.heappush(lst,a+b)
res += a+b
print(res)相关资源:哈夫曼树和哈夫曼编码_哔哩哔哩_bilibili
边栏推荐
猜你喜欢

账务处理程序、记账凭证账务处理程序、汇总记账凭证账务处理程序、科目汇总表账务处理程序、会计信息化概述、信息化环境下会计账务处理的基本要求(此章出1道小题)

redis未授权访问(4-unacc)

SQL注入(6)

laravel-admin 线上访问项目,一直重定向到登录页面

Windows下MySQL数据库报“ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost:8000‘ (10061)”错误解决

The CTF introductory notes of SQL injection

解决flex布局warp自动换行下最后一行居中问题

成本会计的概念、产品成本核算的要求、产品成本核算的对象与成本项目、产品成本的归集和分配(可能考判断)、产品成本计算方法 (三种:产品的品种(品种法),批次(分批法),步骤(分步法))

关于我的大创、论文~

SQL注入(7)
随机推荐
库存现金、现金管理制度、现金的账务处理、银行存款、银行存款的账务处理、银行存款的核对
win10内存占用很高,关闭所有应用程序依然降不下来(win11)
解决composer安装太慢 更换国内镜像
中国大陆开源镜像站汇总
After Alibaba Cloud sets up domain name resolution redirection, I cannot use Chrome to access it
laravel-admin FROM表单同行展示问题
学IT,找工作——移除链表元素
Activity
十大实用的办公工具网站,可以解决你日常100%的问题
英语每日打卡
web安全之目录遍历
CSRF (Cross Site Request Forgery)
还原最真实、最全面的一线大厂面试题
会计账簿、会计账簿概述、会计账簿的启用与登记要求、会计账簿的格式和登记方法
SQL注入(7)
Mysql创建索引
uniapp发布到微信小程序:分包、删减代码全过程
CTF entry md5
一分钟get:缓存穿透、缓存击穿、缓存雪崩
同时安装VirtualBox和VMware,虚拟机如何上网




