定义
哈夫曼树,又称最优树,是一类带权路径长度最短的树。
树的带权路径长度,是树中所有叶子 节点的带权路径长度之和。通常记做WPL=W1*L1+W2*L2+...+Wn*Ln。
例如:
节点ABCDE的权值分别为:1,2,4,5,6。对于图1,WPL=4*3+2*3+1*3+5*3+6*1=42。对于图2,WPL=1*3+2*3+4*2+5*2+6*2=39。以上节点还可以列出其他的树,并计算WPL,可以看出,图2的WPL值是最小的,这颗树即称为最优二叉树或哈夫曼树。
如何建立二叉树呢?
1、将所有节点看成独立的树,且左右子树都为空,没有父节点;
2、挑选两棵根节点权值最小的没有父节点的树,生成一个节点作为它们的父节点,父节点的权值等于他们的权值之和;
3、重复第2步,直到最后变成一棵树。
比如以上ABCDE节点,首先选择A和B形成的父节点(且记为A‘)权值为3,接下来从权值为3,4,5,6中选取,当然就是选3,4,也即A‘和C节点,形成父节点(且记为C’)权值为7,接下来从权值5,6,7中选取最小的两个,当然是5,6.也即是D和E,形成父节点(且记为D‘)的权值为11,最后将D’和C‘形成父节点即为最后的根节点。哈夫曼树就建成了。