霍夫曼编码 c语言程序 求能运行的能算出结果的已知信源:s1=0.20,s2=0.18,s3=0.17,s4=0.15,s5=0.15,s6=0.05,s7=0.05,s8=0.05,给出其中一个霍夫曼码,并求其平均码长和编码效率.

来源:学生作业帮助网 编辑:六六作业网 时间:2024/11/15 20:31:29
霍夫曼编码c语言程序求能运行的能算出结果的已知信源:s1=0.20,s2=0.18,s3=0.17,s4=0.15,s5=0.15,s6=0.05,s7=0.05,s8=0.05,给出其中一个霍夫曼码

霍夫曼编码 c语言程序 求能运行的能算出结果的已知信源:s1=0.20,s2=0.18,s3=0.17,s4=0.15,s5=0.15,s6=0.05,s7=0.05,s8=0.05,给出其中一个霍夫曼码,并求其平均码长和编码效率.
霍夫曼编码 c语言程序 求能运行的能算出结果的
已知信源:s1=0.20,s2=0.18,s3=0.17,s4=0.15,s5=0.15,s6=0.05,s7=0.05,s8=0.05,给出其中一个霍夫曼码,并求其平均码长和编码效率.

霍夫曼编码 c语言程序 求能运行的能算出结果的已知信源:s1=0.20,s2=0.18,s3=0.17,s4=0.15,s5=0.15,s6=0.05,s7=0.05,s8=0.05,给出其中一个霍夫曼码,并求其平均码长和编码效率.
#include "stdio.h"
#include "stdlib.h"
#include
#include
#define n 8
#define m 2*n-1
typedef struct
{
float weight;
int lchild,rchild,parent;
}HTNode;
typedef HTNode HuffmanTree[m];
void InitHuffmanTree(HuffmanTree T)
{
for(int i = 0;i < m;i++)
{
T[i].lchild = T[i].rchild = T[i].parent = -1;
T[i].weight = 0.0;
}
}
void InputWeight(HuffmanTree T)
{
float temp[n] = {0.20,0.18,0.17,0.15,0.15,0.05,0.05,0.05};
for(int i = 0;i < n;i++)
T[i].weight = temp[i];
}
void SelectMin(HuffmanTree T,int i,int *p1,int *p2)
{
int j;
*p1 = *p2 = m-1;
T[m-1].weight = FLT_MAX;
for(j = 0;j = 0;j--)
printf("%d",arr[j]);
printf("\n");
return count;
}
int main()
{
HuffmanTree T;
CreateHuffmanTree(T);
float ave = 0;
for(int i = 0;i < n;i++)
ave += T[i].weight*PrintHuffmanCode(T,i);
printf("平均码长:\t%f\n",ave);
printf("编码效率:\t%f%%\n",ave/ceil(log((double)n)/log((double)2))*100);
system("pause");
}

霍夫曼编码 c语言程序 求能运行的能算出结果的已知信源:s1=0.20,s2=0.18,s3=0.17,s4=0.15,s5=0.15,s6=0.05,s7=0.05,s8=0.05,给出其中一个霍夫曼码,并求其平均码长和编码效率. C语言用do while循环求1到200的奇数个数?要程序能运行的! 请问如何用C语言实现汉字和Unicode编码的转换 求程序 要求:是一个能正常运行的程序 c语言 有一个不多于5的正整数,求它的位数,同时求出它的每位数字? 01背包问题的贪心K阶优化算法设计(物品不可拆分)C语言编码,能实现运行的,急用中!) 求大地测量学高斯正反算,高斯邻带换算C语言或者C#可以运行的程序. 用c语言编写一段程序,求两个集合的交要c语言的,直接粘过来在c++里就可以运行的那种! 用C语言编写一段程序,求两个集合的笛卡尔乘积.并对运行结果截图.一定要对运行结果截图啊, 求判断素数的C语言程序 求双线性插值法的C语言程序! C语言求平方根的程序 求FFT的c语言程序 求用C语言编写的能运行计算四则运算结果的程序,要求输入算式按回车得出结果我想可以输入如:99+9*7-9/34让后计算出答案的 c语言写程序,求一正整数等差数列的前五项的立方和,该数列前四项之和是26,之积是880.希望是能通过运行的, 求用实数编码的遗传算法的简单例子.要求能运行,要有注释. n 个数种取n/2的数的算法可运行的C语言程序 C语言哈夫曼编码问题已知a、b、c、d、e、f各节点的权值分别为18、20、4、13、16、48,采用哈夫曼编码法对各节点进行编码.最好能直接运行的,谢啦. 编写一个c语言程序直到运行,请描述每一步生成的文件类型.