哈夫曼树

哈夫曼树

        哈夫曼树又称最优二叉树,是一种作用于哈夫曼编码的工具,哈夫曼编码是一种无损压缩编码方式,此种压缩方式可以让原始编码长度更短,从而更节省存储空间和传输带宽。

哈夫曼树基本概念

树的路径长度

        两个结点之间的连线称为路径(一般是根节点到叶子节点),路径长度其实就是路径个数;

例:

        结点15到结点2的路径长度是2;结点15到结点4的路径长度是3;

树的路径长度是根节点到每个叶子节点的路径长度之和

        根节点15到叶子节点2的路径长度是2;根节点15到叶子节点4的路径长度是3;

        根节点15到叶子节点8的路径长度是3;根节点15到叶子节点1的路径长度是1;

        树的路径长度=2+3+3+1=8;

        权是指叶子结点的数值(叶子节点的数值代表某一字符出现的频率)

例:

图中叶子节点红色数值。

带权路径长度

        带权的路径长度就是本身的路径长度乘以结点的权值

例:

        结点2的带权路径长度是根节点15到叶子结点2的路径长度乘以结点2的权值。即 2*2=4

        结点4的带权路径长度是根节点15到叶子结点4的路径长度乘以结点4的权值。即 3*4=12

树的带权路径长度(树的代价)

        树的带权路径长度是根节点到每个叶子结点的带权路径总和。

例:

        结点2的带权路径长度是根节点15到叶子结点2的路径长度乘以结点2的权值。即 2*2=4

        结点4的带权路径长度是根节点15到叶子结点4的路径长度乘以结点4的权值。即 3*4=12

        结点8的带权路径长度是根节点15到叶子结点8的路径长度乘以结点8的权值。即 3*8=24

        结点1的带权路径长度是根节点15到叶子结点1的路径长度乘以结点1的权值。即 1*1=1

树的带权路径长度(树的代价)=4+12+24+1=41

中间结点

        其实哈夫曼树中真正的权值只有叶子结点,其他的中间结点都是构造的。

构造哈夫曼树的思想理念

        同一组权值,不同的构造方式得到的树的带权路径长度也是不同的。

构造哈夫曼树的思想理念是树的带权路径越短越好,目标是构造树的带权路径最短的哈夫曼树。

例:

        由权值 2、4、8、1 构造而成的哈夫曼树

        构造方法一中树的带权路径长度是:2*2+3*4+3*8+1+1=41。

        构造方法二中树的带权路径长度是:2*4+3*1+2*3+1*8=25。

根据权值构建树的带权路径最短的哈夫曼树

例题:

        有一组权值:5、29、7、8、14、23、3、11,尝试构造哈夫曼树。

 

 树的带权路径长度

        结点3的带权路径长度是根节点100到叶子结点3的路径长度乘以结点3的权值。即5*3=15。

        结点5的带权路径长度是根节点100到叶子结点5的路径长度乘以结点5的权值。即5*5=25。

        结点7的带权路径长度是根节点100到叶子结点7的路径长度乘以结点7的权值。即4*7=28。

        结点14的带权路径长度是根节点100到叶子结点14的路径长度乘以结点14的权值。即3*14=42

        结点29的带权路径长度是根节点100到叶子结点29的路径长度乘以结点29的权值。即2*29=58

        结点8的带权路径长度是根节点100到叶子结点8的路径长度乘以结点8的权值。即3*8=24。

        结点11的带权路径长度是根节点100到叶子结点11的路径长度乘以结点11的权值。即3*11=15

        结点23的带权路径长度是根节点100到叶子结点23的路径长度乘以结点23的权值。即2*23=46

  树的带权路径长度=15+25+28+42+58+24+15+46=253。

  • 30
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
哈夫曼树(Huffman Tree)是一种特殊的二叉树,用于数据压缩和编码。它的构建过程是根据字符出现的频率来确定每个字符的编码,使得出现频率高的字符具有较短的编码,而出现频率低的字符具有较长的编码。 以下是一个Python实现的哈夫曼树的例子: ```python class TreeNode: def __init__(self, value, freq): self.value = value self.freq = freq self.left = None self.right = None def build_huffman_tree(char_freq): nodes = [TreeNode(char, freq) for char, freq in char_freq.items()] while len(nodes) > 1: nodes = sorted(nodes, key=lambda x: x.freq) left_node = nodes.pop(0) right_node = nodes.pop(0) parent_node = TreeNode(None, left_node.freq + right_node.freq) parent_node.left = left_node parent_node.right = right_node nodes.append(parent_node) return nodes[0] def encode_huffman_tree(root, code='', codes={}): if root is None: return if root.value is not None: codes[root.value] = code encode_huffman_tree(root.left, code + '0', codes) encode_huffman_tree(root.right, code + '1', codes) return codes def decode_huffman_tree(root, encoded_text): decoded_text = '' current_node = root for bit in encoded_text: if bit == '0': current_node = current_node.left else: current_node = current_node.right if current_node.value is not None: decoded_text += current_node.value current_node = root return decoded_text # 示例用法 char_freq = {'a': 5, 'b': 9, 'c': 12, 'd': 13, 'e': 16, 'f': 45} huffman_tree = build_huffman_tree(char_freq) huffman_codes = encode_huffman_tree(huffman_tree) encoded_text = ''.join([huffman_codes[char] for char in 'abcdef']) decoded_text = decode_huffman_tree(huffman_tree, encoded_text) print("Huffman Codes:", huffman_codes) print("Encoded Text:", encoded_text) print("Decoded Text:", decoded_text) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值