码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构之哈夫曼树


    一些基本概念

    在这里插入图片描述
    树的带权路径长度只与叶子节点的路径长度的权值有关!!!
    带权路径长=路径长×权值
    在这里插入图片描述
    给定n个叶子节点
    让我们构造二叉树,其中带权路径长度最小的二叉树叫哈夫曼树

    对应每一个给定权值的n个叶子节点(比如图中四个叶子节点分别为1 3 4 5)都有一个最小的带权路径长度
    1 3 4 5的最小就是25
    所以中间的两个图就是哈夫曼树

    构造哈夫曼树

    给定你固定的叶子节点
    怎么构造?
    1.挑出对应权值最小的两个节点构成一棵树
    2.然后吧这棵树的权值算为对应叶子节点权值之和,把这棵树当做一个节点
    3.再找权值最小的组合就完了
    4.最后组合成的二叉树就是哈夫曼树
    在这里插入图片描述

    由上面的推导可以得出一些哈夫曼树的性质
    在这里插入图片描述

    哈夫曼编码

    在这里插入图片描述
    二进制长度=带权路径长度

    但是右边这颗树显然不是哈夫曼树
    可以用更少的动作传播信息
    这棵树显然要动200次奥

    把右边这棵树化成哈夫曼树
    在这里插入图片描述
    ok然后把对应编码写出来就ok
    这样的话只需要动130次奥

    错误奥

    在这里插入图片描述
    你可能想把A化成1更简单
    但是编码可能是有重复的奥
    比如你想发送CAAABD
    按照A为1的话
    01111111110
    可能翻译成CBBD
    而不是原来的了
    所以一定要按照哈夫曼树,对应节点一定要是叶子节点不能是分支节点
    在这里插入图片描述

    总结

    在这里插入图片描述

  • 相关阅读:
    黑帽python第二版(Black Hat Python 2nd Edition)读书笔记 之 第二章 网络工程基础(2)创建一个TCP代理
    eslint prettier husky代码规范配置
    SAP-PP-查询报工数据
    部署SSM项目到Linux
    2018-2019 ACM-ICPC, Asia Nanjing Regional Contest G. Pyramid(组合数学 计数)
    Hadoop完全分布式搭建
    PHP项目搭建与启动
    Computer Architecture Subtitle:Engineering And Technology
    Harbor(V2.8+) 登录时报错 net/http: TLS handshake timeout
    你的电脑关机吗
  • 原文地址:https://blog.csdn.net/y_k_j_c/article/details/127591355
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号