| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 数据结构——哈夫曼树 -> 正文阅读 |
|
[数据结构与算法]数据结构——哈夫曼树 |
1.介绍哈夫曼树就是树的带权路径长度(即WPL)最小的树,WPL等于所有叶节点的带权路径长度之和。 而叶节点的带权路径长度等于该结点的路径长度与该结点的权值的乘积。 路径长度就是从根节点到该结点所经历的边数。而权值即赋给每个结点的一个数值。 (a)WPL =1*2+3*2+5*2+7*2=32 (b)WPL=1*3+3*3+5*2+7*1=29 (c)WPL=1*2+3*3+5*5+7*1=43 因此,(b)图的WPL最小。 2.算法假设有n个权值,则构造出的哈夫曼树有n个叶子结点。 n个权值分别设为 w1、w2、…、wn,则哈夫曼树的构造规则为: (1) 将w1、w2、…,wn看成是有n 棵树的森林(每棵树仅有一个结点); (2) 在森林中选出两个根结点的权值最小的树合并,作为一棵新树的左、右子树,且新树的根结点权值为其左、右子树根结点权值之和; (3)从森林中删除选取的两棵树,并将新树加入森林; (4)重复(2)、(3)步,直到森林中只剩一棵树为止,该树即为所求得的哈夫曼树。 ?3.特点(1)有n个叶节点的哈夫曼树共有2n-1个结点。 (2)权值越大的叶节点,离根节点越近,权值越小的叶节点,离根节点越远。 (3)哈夫曼树是正则二叉树,只有度为0和2的结点。 (4)哈夫曼树任意非叶节点的左右子树交换后仍是哈夫曼树。因此,哈夫曼树不唯一。 ?4.编码作用?等长编码:每个对象二进制长度相等。 ?不等长编码:每个对象二进制长度不相等。 等长编码虽然容易解码,但编码而成二进制长度太长。常用的子符编码居然也要和不常用的字符编码一样长。 对于不等长编码,对常用的字符进行相对较短的二进制编码表示,不常用的字符进行相对较长的二进制编码表示,减少了解码报文的二进制长度,但容易发生多种解码的方式。 比如说“00”可以表示‘E’,而‘0’可以表示‘G’,那么“00“即可解码成E,也可解码成GG。 因此,有了前缀码,即任何一个字符的编码都不是另一个字符的前缀的编码方式。 我们利用哈夫曼树,结点向左为0,向右为1,这样既能是前缀码易于解码,又能根据字符常用程度赋给其结点权值,其解码任务大大减少。
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/4 17:00:06- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |