当前位置: 首页 > news >正文

香河住房与建设局网站广州网站排名优化公司

香河住房与建设局网站,广州网站排名优化公司,山东信达建设工程有限公司网站,asp.net学校网站整站系统源码今天主要学习了哈夫曼树。 哈夫曼树 哈夫曼树是二叉树的一种,它是一种WPL最优二叉树。 叶子结点(也称叶节点):指的是自己下面不再连接有节点的节点(即末端),称为叶子节点(又称为终…

今天主要学习了哈夫曼树。

哈夫曼树

哈夫曼树是二叉树的一种,它是一种WPL最优二叉树。

叶子结点(也称叶节点):指的是自己下面不再连接有节点的节点(即末端),称为叶子节点(又称为终端结点)

WPL是二叉树的带权路径长度,是指所有叶节点的路径长度乘以当前叶节点的权值之和,打一个比方:

下面有一个字符串,我们以字母出现次数作为权值,a所对应的权值4,我们需要构造一个二叉树,最优WPL的二叉树。 

这是最优的哈夫曼树了,你再也找不到一个比这更优的了,那么它的WPL值为

1*3+1*3+2*2+3*2+4*2=24

还有一个更简洁的计算方法就是将图中的非叶结点值相加,11+4+7+2=24.

存储元素的结点为2*n-1,我们原来有5个结点,最后变成了9个结点

这很巧妙了,接下来讲解如何构建一个哈夫曼树。

在表中找俩个最小值作为结点的左右孩子

很明显是d e所代表的权值,新结点的权值为俩孩子的权值之和,即是2

 

我们需要更新权值的数组,就是删除数组中c d的权值,把新节点的权值写入数组

 

再继续找俩最小值,是c代表的2和另外一个没名字的结点,从下往上插入哦。

重复这些操作知道权值数组没有数值,最后就会变成开篇讲的那样子。

构建哈夫曼树,主要是为了满足哈夫曼编码。

哈夫曼编码是编码的一种,它是用来压缩文本的,主要压缩一段较长并且重复率较高的代码。

之所以那样子建立树,是为了将出现次数多的字符放在前面,出现次数少的字符放在后面,保证访问率的快慢。

 

如上面所示将左边赋值为0,右边为1,我们可以发现一个特性,叶节点所构成的值,是不会有重复前缀的。(当然末尾俩个端点是会有一样的前缀,我们通常按照大小将其左右,左边是较小的,右边的较大的)

 

继而会变成上面那样子,我写的时候带了空格为了美观,实际存储时不带的,我们只需要根据哈夫曼树,按顺序找第一次出现的叶节点的编码,就可以凑成以上的字符串,(你可以自己试一试)。

哈夫曼编码是不等长编码。在一段长的重复率较高的文章特别适用。

http://www.hengruixuexiao.com/news/17582.html

相关文章:

  • 微网站制作提供商推荐淘宝如何刷关键词增加权重
  • wordpress替换本地字体seo工具包
  • 网站内链技巧海外广告优化师
  • 企业门户网站的建设费用金华seo
  • 网站建设使用的什么语言北京seo优化分析
  • 桐乡网站二次开发上海关键词优化公司哪家好
  • 网站建设公司的工资个人怎么做免费百度推广
  • 做网站项目的流程拼多多运营
  • 如何更新网站缓存免费外链网
  • 茂名h5网站建设seo研究协会
  • 企业网站如何推广网站怎么快速排名
  • 做网站ps注意事项天津百度推广排名
  • WordPress动画随音乐变化seo综合查询工具
  • 网站做5级分销合法吗搜索引擎营销的原理
  • wordpress连接本地数据库连云港seo优化
  • 医疗网站建设怎么优化电脑系统
  • 做网站常用的jqueryseo搜索工具栏
  • 百度广州给做网站公司公众号推广
  • 绩溪网站建设网站模板哪里好
  • 网站做qq客服免费网页制作成品
  • 园区门户网站建设方案电商营销推广有哪些?
  • 石家庄哪里做微网站制作网站的基本步骤
  • 温州网站建设成功案例台湾搜索引擎
  • 做营销型网站需要注意哪些点有没有免费的crm系统软件
  • 承接网站开发厦门seo搜索引擎优化
  • 一起做网站17怎么下单推广网站文案
  • vb怎么做网站seo 服务
  • 安康网站开发公司价格长沙谷歌seo
  • 杭州网站建设报价免费大数据网站
  • 做视频的网站多少钱代做seo关键词排名