哈夫曼树的定义
带权路径长度(WPL):设二叉树有n个叶子结点,每个叶子结点带有权值 wk,从根结点到每个叶子结点的长度为 lk,则每个叶子结点的带权路径长度之和就是:

最优二叉树或哈夫曼树: WPL最小的二叉树
哈夫曼树的构造
每次把权值最小的两棵二叉树合并
HuffmanTree Huffman(MinHeap H)
{/* 假设H->Size个权值已经存在H->Elements[]->Weight里 */
int i; HuffmanTree T;
BuildMinHeap(H); //将H->Elements[]按权值调整为最小堆
for (i = 1; i < H->Size; i++) //做H->Size-1次合并
{
T = (HuffmanTree)malloc(sizeof(struct TreeNode));//建立新结点
T->Left = DeleteMin(H); //从最小堆中删除一个结点,作为新T的左子结点
T->Right = DeleteMin(H); //从最小堆中删除一个结点,作为新T的右子结点
T->Weight = T->Left->Weight + T->Right->Weight;//计算新权值
Insert(H, T); //将新T插入最小堆
}
T = DeleteMin(H);
return T;
}
哈夫曼树的特点:
- 没有度为1的结点;
- 哈夫曼树的任意非叶节点的左右子树交换后仍是哈夫曼树;
- n个叶子结点的哈夫曼树共有2n-1个结点;
- 对同一组权值{w1 ,w2 , …… , wn},存在不同构的两棵哈夫曼树,带权路径长度(WPL)相等。

哈夫曼编码
前缀码(prefix code):任何字符的编码都不是另一字符编码的前缀
- 可以无二义地解码
用二叉树进行编码:
- 左右分支:0、1
- 字符只在叶结点上
所有的结点都是叶子结点时,没有二义性,有结点不是叶子结点,存在二义性
注:哈夫曼树的两个孩子没有大小关系


本文详细介绍了哈夫曼树的定义与构造方法,解释了带权路径长度的概念,并探讨了哈夫曼编码的原理,包括前缀码的特性及其在二叉树中的应用。
419

被折叠的 条评论
为什么被折叠?



