1 前言

这篇文章是对网友在文章的下的提问,做出的解答。

2 问题描述

哈夫曼树的基础知识_django

哈夫曼树相关的基础知识。

3 哈夫曼树的定义

哈夫曼树(Huffman Tree):是在叶子结点和权重已经知道的情况下,带权路径长度最小的二叉树,哈夫曼树也被称为最优二叉树。

路径长度:从一个结点到另一个结点多经过的边数就被称为路径长度。

哈夫曼树的基础知识_数据结构_02

树的带权路径长度(WPL):所有叶子结点的权重*路径长度之和,就被称为书的带权路径长度。

下面我们来举个例子:

可知:从A结点到H结点经过三条边,所以路径长度是3,又因为H点的权重为4,所以H点的带权路径长度是3*4 = 12;树的带权路径长度是3*4 + 2*2 + 2*3 + 2*1 = 24。

4 构建一个哈夫曼树

由哈夫曼树的定义可知,权值越小的结点应该在越下层。

哈夫曼树的基础知识_java_03哈夫曼树的基础知识_django_04哈夫曼树的基础知识_django_05

以下图四个结点为例(先将结点从小到大排好):

哈夫曼树的基础知识_python_06

(1)选择两个最小的结点相加得到他们的父结点,并从结点列表中删除这两个结点,加入他们的父结点。

(2)再次选择两个最小的结点相加得到他们的父结点,并从结点列表中删除这两个结点,加入他们的父结点。

哈夫曼树的基础知识_python_07哈夫曼树的基础知识_django_08

(3)重复上面的操作

哈夫曼树的基础知识_算法_09

(4)得到哈夫曼树

5 总结

(1)哈夫曼树(Huffman Tree):

    是带权路径长度最小的二叉树

(2)树的带权路径长度(WPL):

    所有叶子结点的权重*路径长度之和,就被称为书的带权路径长度。

(3)构建哈夫曼树可以从最小的结点由最底层向上构建。

实习编辑:衡辉