哈夫曼树的基本概念
来源:互联网 发布:阿里云dns怎么样 编辑:程序博客网 时间:2024/05/17 23:20
这里有一篇博文讲哈夫曼树,概念讲的挺好的
一、哈夫曼树的概念和定义
什么是哈夫曼树?
让我们先举一个例子。
判定树:
- if(score<60)
- cout<<"Bad"<<endl;
- else if(score<70)
- cout<<"Pass"<<endl
- else if(score<80)
- cout<<"General"<<endl;
- else if(score<90)
- cout<<"Good"<<endl;
- else
- cout<<"Very good!"<<endl;
定义哈夫曼树之前先说明几个与哈夫曼树有关的概念:
路径: 树中一个结点到另一个结点之间的分支构成这两个结点之间的路径。
路径长度:路径上的分枝数目称作路径长度。
树的路径长度:从树根到每一个结点的路径长度之和。
结点的带权路径长度:在一棵树中,如果其结点上附带有一个权值,通常把该结点的路径长度与该结点上的权值
之积称为该结点的带权路径长度(weighted path length)
什么是权值?( From 百度百科 )
计算机领域中(数据结构)
权值就是定义的路径上面的值。可以这样理解为节点间的距离。通常指字符对应的二进制编码出现的概率。
至于霍夫曼树中的权值可以理解为:权值大表明出现概率大!
一个结点的权值实际上就是这个结点子树在整个树中所占的比例.
abcd四个叶子结点的权值为7,5,2,4. 这个7,5,2,4是根据实际情况得到的,比如说从一段文本中统计出abcd四个字母出现的次数分别为7,5,2,4. 说a结点的权值为7,意思是说a结点在系统中占有7这个份量.实际上也可以化为百分比来表示,但反而麻烦,实际上是一样的.
树的带权路径长度:如果树中每个叶子上都带有一个权值,则把树中所有叶子的带权路径长度之和称为树的带
权路径长度。
设某二叉树有n个带权值的叶子结点,则该二叉树的带权路径长度记为:
公式中,Wk为第k个叶子结点的权值;Lk为该结点的路径长度。
示例:
二、哈夫曼树的构造
三、哈夫曼树的在编码中的应用
- 哈夫曼树的基本概念
- 基本概念的澄清
- 一、ATM的基本概念
- J2ME的基本概念
- web services的基本概念
- 几何网络的基本概念
- OSWorkflow的基本概念[原]
- MMS的基本概念
- java的一些基本概念
- 信用卡的基本概念
- CDMA的基本概念
- 工作流的一些基本概念
- J2me的基本概念
- Web标准的基本概念
- osworkflow的基本概念
- UML模型的基本概念
- 马克思主义哲学的基本概念
- 串口通信的基本概念
- Android百度地图学习笔记(一)
- Java反射--通过反射了解集合泛型的本质
- 【SQL Server 2008商务智能BI】数据挖掘导论
- Tomcat实现虚拟目录映射的方法
- C#派生类中如何定义属性控制基类事件,通过派生类属性直接操作基类事件
- 哈夫曼树的基本概念
- .Net——动态创建对象
- Posts Tagged 【String】 Reverse Words in a String
- poj3253 Fence Repair【优先队列】
- POJ1363【栈】
- poj2255Tree Recovery【二叉树重构】
- poj2155Matrix【二位树状数组】
- poj1840Eqs【散列表】
- HDU1496Equations【hash】