第十周 项目5 - 哈曼树

2024-03-15 03:10
文章标签 项目 第十 哈曼

本文主要是介绍第十周 项目5 - 哈曼树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里写图片描述

#include <stdio.h>
#include <string.h>#define N 50        //叶子结点数
#define M 2*N-1     //树中结点总数//哈夫曼树的节点结构类型
typedef struct
{char data;  //结点值double weight;  //权重int parent;     //双亲结点int lchild;     //左孩子结点int rchild;     //右孩子结点
} HTNode;//每个节点哈夫曼编码的结构类型
typedef struct
{char cd[N]; //存放哈夫曼码int start;
} HCode;//构造哈夫曼树
void CreateHT(HTNode ht[],int n)
{int i,k,lnode,rnode;double min1,min2;for (i=0; i<2*n-1; i++)         //所有结点的相关域置初值-1ht[i].parent=ht[i].lchild=ht[i].rchild=-1;for (i=n; i<2*n-1; i++)         //构造哈夫曼树{min1=min2=32767;            //lnode和rnode为最小权重的两个结点位置lnode=rnode=-1;for (k=0; k<=i-1; k++)if (ht[k].parent==-1)   //只在尚未构造二叉树的结点中查找{if (ht[k].weight<min1){min2=min1;rnode=lnode;min1=ht[k].weight;lnode=k;}else if (ht[k].weight<min2){min2=ht[k].weight;rnode=k;}}ht[i].weight=ht[lnode].weight+ht[rnode].weight;ht[i].lchild=lnode;ht[i].rchild=rnode;ht[lnode].parent=i;ht[rnode].parent=i;}
}//实现哈夫曼编码
void CreateHCode(HTNode ht[],HCode hcd[],int n)
{int i,f,c;HCode hc;for (i=0; i<n; i++) //根据哈夫曼树求哈夫曼编码{hc.start=n;c=i;f=ht[i].parent;while (f!=-1)   //循序直到树根结点{if (ht[f].lchild==c)    //处理左孩子结点hc.cd[hc.start--]='0';else                    //处理右孩子结点hc.cd[hc.start--]='1';c=f;f=ht[f].parent;}hc.start++;     //start指向哈夫曼编码最开始字符hcd[i]=hc;}
}//输出哈夫曼编码
void DispHCode(HTNode ht[],HCode hcd[],int n)
{int i,k;double sum=0,m=0;int j;printf("  输出哈夫曼编码:\n"); //输出哈夫曼编码for (i=0; i<n; i++){j=0;printf("      %c:\t",ht[i].data);for (k=hcd[i].start; k<=n; k++){printf("%c",hcd[i].cd[k]);j++;}m+=ht[i].weight;sum+=ht[i].weight*j;printf("\n");}printf("\n  平均长度=%g\n",1.0*sum/m);
}int main()
{int n=8,i;      //n表示初始字符串的个数char str[]= {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'};double fnum[]= {0.07,0.19,0.02,0.06,0.32,0.03,0.21,0.1};HTNode ht[M];HCode hcd[N];for (i=0; i<n; i++){ht[i].data=str[i];ht[i].weight=fnum[i];}printf("\n");CreateHT(ht,n);CreateHCode(ht,hcd,n);DispHCode(ht,hcd,n);printf("\n");return 0;

}

这篇关于第十周 项目5 - 哈曼树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/810599

相关文章

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排