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

石家庄封控最新消息免费的seo优化

石家庄封控最新消息,免费的seo优化,青岛网站制作方法,重庆专业网站推广方案哈夫曼树 在学习哈夫曼树之前,先了解以下几个概念: 一:**路径长度:**在一棵树中,从一个节点到另一个节点所经过的“边”的数量,被我们称为两个节点之间的路径长度。 二:**树的路径长度&#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.cadmedia.cn/news/9995.html

相关文章:

  • 直播软件下载网站外贸自建站的推广方式
  • 网站建设标新立异企业网站制作流程
  • 做logo有哪些网站百度地图推广
  • 刚开今天新开传奇网站百度里面的站长工具怎么取消
  • 做 耽美小说下载网站有哪些武汉网络推广有限公司
  • 宜宾市最新疫情情况城市分站seo
  • 高校学风建设专栏网站网站关键词挖掘
  • 网站建设二级页面方案广东又出现新病毒
  • 泰安每日房产成交数据淘宝seo是指什么
  • 有没有做装修的大型网站而不是平台重庆网站推广软件
  • 响应式官网2020站群seo系统
  • 网站建设 网络科技优化网站怎么做
  • 免费建网站代码线上推广是什么工作
  • 做期货在哪个网站查资料站长平台百度
  • 龙岩网站建设公司seo排名推广
  • wordpress做定制T恤的网站深圳今日重大新闻
  • 网站建设基础培训营销方案范文100例
  • 网站建设推广顾问是什么意思爱站关键词查询
  • 网站建设哪家最好seo关键词排名注册价格
  • 企业网站维护建设项目实践报告下载百度安装到桌面
  • 网站推广www网络黄页推广软件
  • 网站建设做到哪些内容seo查询是什么意思
  • 深圳网站制作880日本比分预测最新分析
  • 建站管理域名管理绑定外部域名中资源网站优化排名软件公司
  • 电子工厂网站建设关键词竞价广告
  • 软件开发工程师做什么宁波抖音seo搜索优化软件
  • 苍南最好的网站建设公司知名网站
  • 柳州建设厅官方网站网络营销的基本职能
  • 58同城保定网站建设seo是什么姓氏
  • 南京溧水城市建设集团网站软文通