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

江门英文网站建设怎么优化网站排名才能起来

江门英文网站建设,怎么优化网站排名才能起来,vue移动端开发,软件管理app哈夫曼树 在学习哈夫曼树之前,先了解以下几个概念: 一:**路径长度:**在一棵树中,从一个节点到另一个节点所经过的“边”的数量,被我们称为两个节点之间的路径长度。 二:**树的路径长度&#xf…

哈夫曼树

在学习哈夫曼树之前,先了解以下几个概念:
一:**路径长度:**在一棵树中,从一个节点到另一个节点所经过的“边”的数量,被我们称为两个节点之间的路径长度。
二:**树的路径长度:**这是指从树根到每一个节点的路径长度的总和对于节点数相同的树来说,路径长度最短的是完全二叉树。
三:**节点带权的路径长度:这是指树的根节点到该节点的路径长度和该节点权重的乘积。
:树的带权路径长度:**在一棵树中,所有叶子节点的带权路径长度之和,被称为树的带权路径长度,也被简称为WPL,这是每一个节点的对应的权值乘以对应的路径长度之和。
如图所示:
image-20250330140116571

对于该图:
树路径长度就为1+1+2+2+3+3+4+4=20
A节点带权的路径长度=1*5=5
树的带权路径长度WPL=5×1+15×2+40×3+30×4+10×4=315
我们可以试想,同样的两颗二叉树,一个WPL小,一个WPL大,那么小的一定会在性能上优于大的,所以我们引出另外一个名词——哈夫曼树,即WPL最小的二叉树。
那我们如何才知道一棵树是不是哈夫曼树呢?
构造哈夫曼树:
首先,假如我们有5个节点,它们的权值分别是:A5, E10, B15, D30, C40。
在这些节点中,我们找到权值最小的两个节点,这里是A5和E10。我们将这两个节点合并,生成一个新的节点,新节点的权值是A5和E10的权值之和,即15。这样,我们就得到了新的节点列表:AE15, B15, D30, C40
我们再次在新的节点列表中找到权值最小的两个节点,这次是AE15和B15。我们将这两个节点合并,生成一个新的节点,新节点的权值是AE15和B15的权值之和,即30。这样,我们就得到了新的节点列表:AEB30, D30, C40
我们继续在新的节点列表中找到权值最小的两个节点,这次是AEB30和D30。我们将这两个节点合并,生成一个新的节点,新节点的权值是AEB30和D30的权值之和,即60。这样,我们就得到了新的节点列表:AEBD60, C40。
最后,我们将剩下的两个节点合并,生成一个新的节点,新节点的权值是AEBD60和C40的权值之和,即100。这样,我们就得到了最终的哈夫曼树。
比如这两个图,就是第一步的操作的举例:

image-20250330172845255

当完成后,我们只需要比较一下当前WPL和我们的WPL,若相等,则就是哈夫曼树。
对于一颗哈夫曼树,有:
哈夫曼树中权越大的叶子离根越近
具有相同带权结点的哈夫曼树不唯一
哈夫曼树只有度为0或2的结点,没有度为1的结点
包含n个叶子结点的哈夫曼树共有2n-1个结点(如上图,叶子节点为3,总共2*3-1==5个节点)
n棵二叉树要经历n-1次合并可以形成哈夫曼树
哈夫曼编码:
哈夫曼编码是一种用于无损数据压缩的熵编码(即编码效率最高)算法。它是一种可变字长编码方式,比起定长编码的ASCII编码来说,哈夫曼编码能节省很多的空间,因为每一个字符出现的频率不是一致的。

哈夫曼编码的基本原理和流程如下:

将字符集C作为叶子节点;
将频率集W作为叶子节点的权值;
使用C和W构造哈夫曼树;
对哈夫曼树的所有分支,左子树分支编码为0,右子树分支编码为1;
通过上述流程,即完成了哈夫曼编码。
下面我们来用代码实现一颗哈夫曼树:

首先是结构体的定义:

	struct haftree {double weight;//节点权值char c;//节点名字int lchild, rchild, parent;
};
接下来是各个函数的定义:
1.找出各权值中最小的两个:
void selcet(struct haftree* array, int x, int* m1, int* m2) {double min1 = DBL_MAX;double min2 = DBL_MAX;for (int i = 1; i <= x; i++) {if (array[i].weight < min1 && array[i].parent == 0) {//在构建哈夫曼树的过程中,我们需要选择权重最小的两个结点进行合并,构建出新的结点。为了避免重复选择已经合并过的结点,我们需要在选择最小权重结点的时候排除已经合并的结点。因此,需要通过array[i].parent == 0来判断结点是否已经是其他结点的子结点,如果是,则不考虑这个结点。min1 = array[i].weight;*m1 = i;}}for (int j = 1; j <= x; j++) {if (array[j].weight < min2 && j != *m1 && array[j].parent == 0) {min2 = array[j].weight;*m2 = j;}}
}
2.构建哈夫曼树:
void createhaftree(struct haftree*array,int n) {for (int i = n + 1; i <= 2 * n - 1; i++) {int m1,m2;Select(array, i - 1, &m1, &m2);array[i].weight = array[m1].weight + array[m2].weight;array[i].lchild = m1;array[i].rchild = m2;array[m1].parent = i;array[m2].parent = i;}
}
3.哈夫曼编码:
void HuffmanCoding(struct haftree* array, int n) {// 一个自定义的数据结构,用于存储哈夫曼树的节点char cd[n + 1];int start;cd[n] = '\0';for (int i = 1; i <= n; i++) {start = n;int c = i;int f = array[i].parent;while (f != 0) {if (array[f].lchild == c)cd[--start] = '0';elsecd[--start] = '1';c = f;f = array[f].parent;}printf("%s\n", &cd[start]);}
}
4.初始化与预处理:
for (int i = 1; i <= n; i++) {array[i].weight = weights[i - 1];array[i].c = chars[i - 1];array[i].parent = 0;array[i].lchild = 0;array[i].rchild = 0;
}
// 初始化非叶子节点
for (int i = n + 1; i < 2 * n; i++) {array[i].weight = 0;array[i].c = '\0'; // 非叶子节点没有字符array[i].parent = 0;array[i].lchild = 0;array[i].rchild = 0;
}
完整代码如下:
#include <stdio.h>
#include <float.h>
#include <limits.h>
struct haftree {double weight;//节点权值char c;//节点名字int lchild, rchild, parent;
};
void Select(struct haftree* array, int x, int* m1, int* m2) {double min1 = DBL_MAX;double min2 = DBL_MAX;for (int i = 1; i <= x; i++) {if (array[i].weight < min1 && array[i].parent == 0) {min1 = array[i].weight;*m1 = i;}}for (int j = 1; j <= x; j++) {if (array[j].weight < min2 && j != *m1 && array[j].parent == 0) {min2 = array[j].weight;*m2 = j;}}
}
void createhaftree(struct haftree* array, int n) {for (int i = n + 1; i <= 2 * n - 1; i++) {int m1, m2;Select(array, i - 1, &m1, &m2);array[i].weight = array[m1].weight + array[m2].weight;array[i].lchild = m1;array[i].rchild = m2;array[m1].parent = i;array[m2].parent = i;}
}
void HuffmanCoding(struct haftree* array, int n) {char cd[n + 1];int start;cd[n] = '\0';for (int i = 1; i <= n; i++) {start = n;int c = i;int f = array[i].parent;while (f != 0) {if (array[f].lchild == c)cd[--start] = '0';elsecd[--start] = '1';c = f;f = array[f].parent;}printf("%s\n", &cd[start]);}
}
int main() {int n = 5; // 假设有5个字符struct haftree array[2 * n]; // 创建哈夫曼树数组double weights[] = { 0.1, 0.15, 0.2, 0.25, 0.3 }; // 假设这是每个字符的权重char chars[] = { 'a', 'b', 'c', 'd', 'e' }; // 这是每个字符
// 初始化叶子节点
for (int i = 1; i <= n; i++) {array[i].weight = weights[i - 1];array[i].c = chars[i - 1];array[i].parent = 0;array[i].lchild = 0;array[i].rchild = 0;
}
// 初始化非叶子节点
for (int i = n + 1; i < 2 * n; i++) {array[i].weight = 0;array[i].c = '\0'; // 非叶子节点没有字符array[i].parent = 0;array[i].lchild = 0;array[i].rchild = 0;
}
createhaftree(array, n);
HuffmanCoding(array, n);
return 0;
}
http://www.dtcms.com/wzjs/824190.html

相关文章:

  • 网站建设价格如何小程序商城代运营
  • 城市建设理论研究官方网站电子商务网站模板
  • 哪里有做网站企业深圳线上网络推广公司
  • 网站建设在线菜鸟教程网站建设项目报告
  • 网站伪静态化开发公众号
  • 网站建设报价明细单公司制作一个网站
  • ae做动画教程网站sem优化专员
  • 搜索引擎如何找到网站爱站网是什么
  • 做视频网站用什么服务器上海外贸上市公司有哪些
  • dede世界杯网站模板wordpress修改登陆
  • 网站案例演示自己做视频网站只能用地址连接
  • 福建网站建设科技有限公司安徽省建设监理协会新网站
  • 肇庆网站建设维护河源市做网站
  • 天水企业网站建设成都大邑网站建设
  • 厦门网站制作企业竞价托管选择微竞价
  • 期末作业做网站的心得体会怎么做卖东西的网站
  • 奉贤专业网站建设安徽安庆属于南方还是北方
  • 做彩平的网站js 调用本地wordpress
  • 青岛 企业网站建站html网页制作个人主页制作教程
  • 做推文封面图网站wordpress的插件目录
  • wordpress 终极优化最新seo黑帽技术工具软件
  • 旅行社网站建设青岛seo优化
  • org的域名网站深圳做网站哪个公司好
  • 深圳网站建设方案服务公司互动营销
  • 门户网站有哪几个熟人做网站怎么收钱
  • 有做材料的网站吗秦淮区建设局网站
  • 北京网站建设w亿玛酷1订制排版
  • soho外贸网站建设网页链接制作生成器
  • 福建住房城乡建设厅网站株洲seo优化官网
  • pexels素材网站深圳中小企业网站制作