本文主要是介绍sdutoj 3345 数据结构实验之二叉树六:哈夫曼编码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
题目链接:点击打开链接
题目描述
字符的编码方式有多种,除了大家熟悉的ASCII编码,哈夫曼编码(Huffman Coding)也是一种编码方式,它是可变字长编码。该方法完全依据字符出现概率来构造出平均长度最短的编码,称之为最优编码。哈夫曼编码常被用于数据文件压缩中,其压缩率通常在20%~90%之间。你的任务是对从键盘输入的一个字符串求出它的ASCII编码长度和哈夫曼编码长度的比值。
输入
输出
示例输入
AAAAABCD
THE_CAT_IN_THE_HAT
示例输出
64 13 4.9
144 51 2.8
ps:因为每次都要更新排序,所以用的multiset存的
<span style="font-size:18px;">///数据结构实验之二叉树六:哈夫曼编码 #include <iostream> #include<cstdio> #include<set> #include<algorithm> #include<cstring>using namespace std; char a[100000]; char b[1000]; int main() {while(cin>>a){int len=strlen(a);int n=len*8;memset(b,0,sizeof(b));for(int i=0; i<len; i++){b[(int)a[i]]++;}multiset<int >q;multiset<int >::iterator cp;for(int i=0; i<=500; i++){if(b[i]!=0){q.insert(b[i]);}}int x1,x2;int k=0;while(!q.empty()){x1=*(q.begin());q.erase(q.begin());if(!q.empty()){x2=*(q.begin());q.erase(q.begin());q.insert(x1+x2);k=k+(x1+x2);}}double mn;mn=(double)n/k;printf("%d %d %.1lf\n",n,k,mn);}return 0; } </span>
这篇关于sdutoj 3345 数据结构实验之二叉树六:哈夫曼编码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!