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

wordpress网站模板下载dede网站幻灯片

wordpress网站模板下载,dede网站幻灯片,活动策划网站源码,wordpress手机端装换1.前置知识讲解 1.树的带权路径长度: 从树的根到树的其中一个叶子结点的路径长度与该叶子结点权值的乘积为该叶子结点的带权路径长度。 一棵树的所有叶子结点的带权路径长度之和就是树的带权路径长度 eg: 对于权值为1的叶子结点来说:他的带权…

1.前置知识讲解

1.树的带权路径长度:

从树的根到树的其中一个叶子结点的路径长度与该叶子结点权值的乘积为该叶子结点的带权路径长度。

一棵树的所有叶子结点的带权路径长度之和就是树的带权路径长度

eg:

对于权值为1的叶子结点来说:他的带权路径长度就是根节点到他的距离(2)X自己的权值(1),得到结果为2

对于整棵树来说:带权路径长度就是所有的叶子结点的带权路径长度之和
2.哈夫曼树:

在含有n个带权叶子结点的二叉树中,树的带权路径长度最小的二叉树就是哈夫曼树,也叫最优二叉树

3.哈夫曼算法:用来构建哈夫曼树的算法

第一步:初始化

我们将所有的带权叶子结点分别当成一颗颗树,那么所有叶子结点就组成了一片森林

第二步:树的合并

我们将权值最小的叶子结点从森林取出,当成一颗新树的左右子节点,然后合成一颗新树,这颗新树的根节点的值为左右子节点权值相加,然后我们把这颗新树的根节点当成森林中的一颗新树

第三步:重复第二步直到森林中只有一棵树为止

如此我们就得到了一颗哈夫曼树

eg:假设我们的带权叶子结点有(1,2,3,4,5,6)

第一步:将最小的带权节点1,2合并为一颗树。合并后将新的树的根节点3放入森林

森林:3,3,4,5,6

第二步:将3,3合并为一棵树,将6放入森林

森林:4.5.6.6

第三步:将4,5合并为一棵树,将9放入森林

森林:6.6.9

第四步:将6.6合并为新树,将12放入森林

森林:9.12

第五步:将9.12合并为新树,将21放入森林

森林:21

此时只有一颗树了,哈夫曼树构建完成

整棵树的带权路径和求法:

直接在构建的同时将所有子节点的权值累加起来即可

eg:

其实带权路径也可以用另一种方式理解,那就是我们其实是将权值赋予给了路径,比如权值为2的叶子结点,他的单位路径值就从1赋值为了2。我们看左图,权值为1的带权路径就是1,权值为2的带权路径位2。

那么我们再看看右图:

按照传统求法我们得到树的带权路径和为9,用构建哈夫曼树时所有子节点累加也可以得到结果9

疑问:为什么可以这样计算树的带权路径和?
对于1,2的根节点3其实我们加上他的值的时候,本质上是加上1,2的 新一段路径长度的值

4.哈夫曼编码:一种用于压缩的编码方式

比如说我们有一个字符串“aabbccdd”,正常来说我们需要给每个字符8bit位置存储,但是经过编码后我们甚至可以只用2bit表示一个字符

编码流程:

1.统计字符的出现次数

2.将次数作为对应字符叶子结点权值构建哈夫曼树

3.构建完成后给所有相对于其根节点的左路径标为0,给右路径标为1,根据路径得出最终编码

eg:

2.算法题讲解

 

审题:

本题需要我们找到编码后字符串的最短长度

思路:
方法一:哈夫曼编码

字符串最短长度其实就是题目中说的哈夫曼编码长度乘字符出现次数,而哈夫曼编码长度等于字符路径长度,字符出现次数等于叶子结点权值。

所以题目其实就是要我们求经过哈夫曼树构建后的树带权路径和

解题:
 

#include<iostream>
#include<vector>
#include<queue>
using namespace std;
typedef long long ll;
int n;
priority_queue<ll, vector<ll>, greater<ll>> p;
int main()
{//数据录入cin >> n;for (int i = 1; i <= n; i++){ll a;cin >> a;p.push(a);}//哈夫曼编码ll answer = 0;while (p.size() != 1){ll a = p.top(); p.pop();ll b = p.top(); p.pop();answer += a + b;p.push(a + b);}cout << answer << endl;return 0;
}

1.我们需要快速获得最小的两个权值,所以我们使用小堆结构,而priority_queue默认是大堆,所以我们要传greater仿函数来控制排序逻辑为小堆

2.我们计算树的带权路径和的方法是累加构造哈夫曼树过程中的所有子节点的权值

哈夫曼编码


文章转载自:

http://dzLRUKme.rhkgz.cn
http://YyMeF1bk.rhkgz.cn
http://LWRncSUQ.rhkgz.cn
http://vIri8x0m.rhkgz.cn
http://olcWBDcF.rhkgz.cn
http://FFwGlP9X.rhkgz.cn
http://p6Nsxlds.rhkgz.cn
http://VHMeQKPY.rhkgz.cn
http://QvdFXgJd.rhkgz.cn
http://EcfG0LDf.rhkgz.cn
http://unw6Meaz.rhkgz.cn
http://ZARVGvkE.rhkgz.cn
http://JWOgKsmk.rhkgz.cn
http://laSv0j79.rhkgz.cn
http://AWCXCqfr.rhkgz.cn
http://M87AJ7oj.rhkgz.cn
http://SnI7yYX4.rhkgz.cn
http://7XBH5XWD.rhkgz.cn
http://LKH9TxCx.rhkgz.cn
http://10eGWXN4.rhkgz.cn
http://YW8FaYSK.rhkgz.cn
http://II6WiGox.rhkgz.cn
http://VPJNgOZd.rhkgz.cn
http://mCMSnUSR.rhkgz.cn
http://1fhApPp4.rhkgz.cn
http://iRmedEXB.rhkgz.cn
http://sGQWxnvW.rhkgz.cn
http://NhpXcHKw.rhkgz.cn
http://pVfPPjy4.rhkgz.cn
http://6RIhfaAk.rhkgz.cn
http://www.dtcms.com/wzjs/632826.html

相关文章:

  • 有没有专业做淘宝网站吗外贸网络推广专员
  • 建设在线教育网站他达拉非的副作用和危害
  • 网站没有做适配 怎么办一起做网店类似网站
  • 网站用哪些系统做的比较好用seo最新教程
  • 有没有兼职做设计的网站吗三合一网站管理系统
  • 四平市城乡建设局网站自助建站免费建站平台
  • 长沙建设公司网站短视频运营公司
  • 顺的网站建设效果南昌专业做网站公司
  • 网站用哪些系统做的网店怎么运营推广
  • 国外php网站源码网站建设怎么添加背景音乐
  • 深圳网站建设美橙互联wordpress自己写界面
  • pc端网站做移动适配正规十大电商平台
  • vs做网站怎么添加子页外包制作app软件要多少钱
  • 网站更换主机需要怎么做深圳乐创网站建设
  • 网页设计与网站建设 石油大学该网站无备案
  • 北京网站建设 网络推广专业网站优化制作公司
  • 怎样建设学校网站学做窗帘的网站
  • 建设小说网站用什么软件下载wordpress副标题修改代码
  • 大型网站技术架构演进与性能优化网站开发模块的需求分析
  • 企业网站建设毕业设计论文wordpress加友情链接
  • 淮北网站三合一建设顺德新网站制作
  • 深圳网站设计互联网品牌网站域名费会计分录怎么做
  • 侗族网站建设如何验证网站所有权
  • 做网站获流量做旅游网站的公司
  • 南京百度网站制作校园推广活动
  • 现在c 做网站用什么网站界面设计材料收集
  • 建设卡开通网银网站网页创意与设计50例
  • 欧美网站欣赏软件网站模板
  • 厦门网站个人制作设备高端网站建设
  • 百度竞价做网站建设分销 社交 电商系统