//编码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<queue>
#include<fstream>
#include<map>
using namespace std;typedef struct HuffmanNode{int w;//节点的权值 int ld, rd;//左右孩子节点 int p;//父节点 char ch;//当前节点的字符HuffmanNode(){ld = rd = p = -1;}
}huffmanNode, *pHuffmanNode;typedef pair<int, int> pii;//haffuman节点和它的编号 bool operator > (pii x, pii y){return x.first > y.first;
}struct Huffman{int cntNode;//总结点的个数 string orgCode;string huffmanCode;pHuffmanNode huffman =    NULL;priority_queue<pii, vector<pii>, greater<pii> >qNode;map<string, char> huffmanMapx;//哈夫曼编码对应字符 map<char, string> huffmanMapy;//字符对应哈夫曼编码 void initHuffman(char *str){orgCode = str;cntNode = 0;int cnt[150];//统计每一个节点的个数 memset(cnt, 0, sizeof(cnt));for(int i=0; str[i]; ++i){if(cnt[str[i]]==0) ++cntNode;++cnt[str[i]];}huffman = new HuffmanNode[2*(cntNode)];int index = 0;for(int i=0; i<150; ++i){if(cnt[i]!=0){huffman[index].w = cnt[i];huffman[index].ch = i;qNode.push(make_pair(huffman[index].w, index));++index;}}while(qNode.size()>=2) {pii ldPii = qNode.top();qNode.pop();pii rdPii = qNode.top();qNode.pop();huffman[index].w = ldPii.first + rdPii.first;huffman[index].ld = ldPii.second;huffman[index].rd = rdPii.second;huffman[ldPii.second].p = index;huffman[rdPii.second].p = index;qNode.push(make_pair(huffman[index].w, index));++index; }}void huffmanCoding() {for(int i=0; i<cntNode; ++i){//从每一个孩子节点向上寻找 string code = "";for(int child=i, p=huffman[child].p; ~p; child = p, p = huffman[child].p) {if(huffman[p].ld == child){//左子树 code += '0';} else if(huffman[p].rd == child){//右子树code += '1';} }reverse(code.begin(), code.end());huffmanMapx.insert(make_pair(code, huffman[i].ch));huffmanMapy.insert(make_pair(huffman[i].ch, code));}}void outHuffmanTree(fstream &fout, int f){if(huffman[f].ld==-1 && huffman[f].rd==-1){fout<<0<<" ";return ;} else {fout<<1<<" ";outHuffmanTree(fout, huffman[f].ld);outHuffmanTree(fout, huffman[f].rd);}}void outHuffmanCode(){huffmanCode = "";//存储字符串的哈夫曼编码之后的内容 fstream fout("out.txt", ios_base::out);for(int i=0; i<orgCode.length(); ++i){huffmanCode += huffmanMapy[orgCode[i]];}cout<<huffmanCode<<endl;fout<<huffmanCode<<endl;//想文件中输入huffman编码int f = 2*cntNode-2;//huffman树的父节点outHuffmanTree(fout, f);fout<<endl;for(map<string, char>::iterator it = huffmanMapx.begin(); it!=huffmanMapx.end(); ++it){cout<<it->first << " -> " << it->second<<endl; fout<<it->first<<" "<<it->second<<endl; //向文件中输入HuffmanMap }}
};int main(){char str[100];Huffman huffman;gets(str);huffman.initHuffman(str);huffman.huffmanCoding();huffman.outHuffmanCode();return 0;
}
//译码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<queue>
#include<fstream>
#include<map>
using namespace std;typedef struct HuffmanTreeNode{HuffmanTreeNode *ld, *rd;HuffmanTreeNode(){ld = NULL;rd = NULL;}
} *pHuffmanTreeNode;struct Huffman{pHuffmanTreeNode T;string code;map<string, char>huffmanMapx;void buildT(fstream &fin, pHuffmanTreeNode &T){int w;fin>>w;T = new HuffmanTreeNode(); if(w==0)return ;buildT(fin, T->ld);buildT(fin, T->rd);}void outT(pHuffmanTreeNode T){if(T->ld != NULL){cout<<0<<endl;outT(T->ld); }else return;if(T->rd != NULL){cout<<1<<endl;outT(T->rd); }}void initHuffmanTree(){fstream fin("in.txt", ios_base::in);T = NULL;fin>>code;buildT(fin, T);//outT(T);string mapContent;while(getline(fin, mapContent)){int index = mapContent.find_first_of(' ');huffmanMapx.insert(make_pair(mapContent.substr(0, index), mapContent[index+1]));}}void outHuffmanEncode(){string encode = "", cd="";initHuffmanTree();pHuffmanTreeNode p = T;for(int i=0; i<code.length(); ++i){if(p->ld==NULL && p->rd==NULL){encode+=huffmanMapx[cd];cd="";--i;p=T;} else {cd+=code[i];if(code[i]=='0')p=p->ld;else if(code[i]=='1')p=p->rd;}if(i==code.length()-1) encode+=huffmanMapx[cd];}cout<<encode<<endl;}
};int main(){Huffman huffman;huffman.outHuffmanEncode();return 0;
}

操作流程:

文本内容:aaaaaaabbbbbccdddd, and I am a student, my name is hjzgg!

1.首先利用''编码"工具将文本编码,会输出一个out.txt的文本,将out.txt文本中的内容发送给你的好友。

2.接受到out.txt文本的内容后,将内容复制到文本名为in.txt的文件中,利用"译码"工具(保证in.txt和译码工具在同一目录下)可以查看文本内容。

3.其中out.txt文本的格式如下:

Huffman树进行编码和译码相关推荐

  1. 优先级队列实现哈夫曼树的编码和译码

    //优先级队列实现的哈夫曼树的编码和译码 #include<iostream> #include<queue> #include<string> using nam ...

  2. 数据结构源码笔记(C语言):Huffman树字符编码

    #include <stdio.h> #include<string.h> #define N 10 /*待编码字符的个数,即树中叶结点的最大个数*/ #define M 2* ...

  3. Huffman树在编码中有着广泛的应用。在这里,我们只关心Huffman树的构造过程。

    Huffman树在编码中有着广泛的应用.在这里,我们只关心Huffman树的构造过程. 给出一列数{pi}={p0, p1, -, pn-1},用这列数构造Huffman树的过程如下: 1. 找到{p ...

  4. 基础练习 Huffuman树 _C语言和C++描述!(Huffman树在编码中有着广泛的应用。在这里,我们只关心Huffman树的构造过程。   给出一列数{pi}={p0, p1, …, pn-1)

    问题描述 Huffman树在编码中有着广泛的应用.在这里,我们只关心Huffman树的构造过程. 给出一列数{pi}={p0, p1, -, pn-1},用这列数构造Huffman树的过程如下: 1. ...

  5. c语言赫夫曼树的编码与译码,哈夫曼树与编码译码实现

    一.哈弗曼树的基本概念. 哈夫曼树,又称最优树,是一类带权路径长度最短的树.下面有几个概念: (1)路径. 树中一个结点到另一个结点之间的分支构成这两个结点之间的路径. (2)路径长度. 路径上的分枝 ...

  6. Huffman树及其编码实现

    一个拥有n个待编码的字符串,其哈夫曼树具有 2n-1个节点. 用构造哈夫曼树的过程生成的二进制前缀编码.哈夫曼树是一类带权路径长度最短的树. 特点:长度最短 哈夫曼编码是哈夫曼树的一个应用.哈夫曼编码 ...

  7. 哈夫曼树--链式结构(建立huffman树、编码、解码)

    引子: 用链式结构来建立哈夫曼树. 总体思路是: 将每一棵树(这是每一棵树只有一个节点,头节点)放在一个优先队列中(下面的是链表实现的优先队列),频率(rate)小的在队列头,取出队列头两个,频率相加 ...

  8. Huffman编码与译码

    Huffman树的构建说明 样例分析: 对于一个字符串输入 c b a x y y z z 若采用ASCII 编码方式,每一个字符都是char类型,每个字符所占空间为一个字节,因此8个字符就需要8个字 ...

  9. 数据结构-Huffman树

    Huffman树的编码和解码 思想:1.统计字符串每个字母出现的个数2.依次取出两个最小的字母进行合并(分别作为左右子节点,另左子节点<右子节点的值),使用他们值之和作为根节点的值,并将根节点加 ...

最新文章

  1. ADO.NET 2.0中的SqlCommand.ExecutePageReader
  2. C#在WinFrom中Get/Post请求及QQ农场Cookie保存
  3. parallelstream启动的线程数_谈谈并行流parallelStream
  4. [Android] 给图像加入相框、圆形圆角显示图片、图像合成知识
  5. 虚拟机中web服务器的搭建,虚拟机下搭建web服务器
  6. PCM信号是什么信号?
  7. Python : *args和**kwargs是什么东东呢?
  8. JAVA(1)-----JAVA基础知识
  9. ajax get post
  10. 眼底图像血管增强与分割--(1)匹配滤波算法原理及实现
  11. 3810.最长连续休息时间-AcWing题库
  12. 最新卡巴斯基密码管理器:注重便利性和强化密码控制
  13. mongovue 导入mysql_使用mongovue把sqlserver数据导入mongodb的步骤
  14. 金蝶盘点机PDA仓库条码管理:仓库如何盘点
  15. [转]如何在NIOS II中读写EPCS剩余空间
  16. OSPO Summit 2022 正式启动!OSPO Summit 2022 Launched!
  17. 互联网晚报 | 11/11 星期五 | 苹果默认不再接受隔空投送;扎克伯格就万人被裁视频致歉;波司登旗舰店被曝先提价再打折...
  18. 数据结构 --- 图的遍历 DFS、BFS
  19. navicat 快捷键使用
  20. c语言修仙键盘,最后一口气ulbsans电脑版

热门文章

  1. unity game和scene效果不一样_KTV装修设计:如何让消费者体验到不一样的KTV娱乐效果...
  2. ci框架 mysql 超时时间_mysql 字符集和校验规则( CHARSET amp; COLLATE)
  3. apache实验报告 linux_Linux实验报告
  4. 从《四驱兄弟》到“联想中国”
  5. Linux系统编程---5(共享存储映射,存储映射I/O,mmap函数,父子进程间通信,匿名映射)
  6. bob-tong 字符串函数之Strtok()函数
  7. mysql远程连接权限grant all privileges on *.* to ‘root‘@‘%‘ identified by ‘123456‘ with grant option语句报错
  8. 【计算机思维】面向人的开发 站在巨人的肩膀上
  9. 文件操作(stat函数)
  10. 1136 A Delayed Palindrome (20 分)