Huffman树进行编码和译码


//编码
#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文本的格式如下:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398437.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一幅长文细学JavaScript(五)——ES6-ES11新特性

5 ES版本 摘要 ES5的先天不足致使ES后续版本的发展&#xff0c;这也是前端人员绕不开的一个点。如果我们想要在工作和面试中轻松解决问题&#xff0c;那么了解ES6-ES11是必不可少的。 在本文中&#xff0c;我将采用一种更加通俗的方式来讲述这一块知识点&#xff0c;而不是照搬…

一幅长文细学Vue(一)——Webpack打包工具

1 项目开发工具 摘要 ​ 在本文中&#xff0c;我们会详细讨论webpack是如何打包发布项目&#xff0c;不过对于Vue来说&#xff0c;Vite可以做到和webpack一样的功能。 声明&#xff1a;如果想要看懂此文章&#xff0c;需具备node.js中npm的知识。 作者&#xff1a;来自ArimaMis…

I00005 打印直角三角形字符图案

曾经的计算机&#xff0c;没有显示屏&#xff0c;人们操作计算机时&#xff0c;用打印机记录执行的操作命令。 后来有了显示屏&#xff0c;不过最初的显示屏是字符频幕&#xff0c;输出只能是字符。 即使是今日&#xff0c;计算机已经进入多窗口图形界面时代&#xff0c;有时程…

动态数组使用

1 #include<stdio.h>2 #include<stdlib.h>3 4 int main()5 {6 int i;7 int n; //用于记录输入的整数的个数 8 int *p; //用于指向动态数组的存储空间 9 int sum0,average; //用于记录输入的整数的和与平均值 10 11 scanf("%d"…

Linux下安装Redis及搭建主从

Linux下安装Redis 首先在官网下载对应版本的redis包&#xff0c;这里本人使用的是redis-4.0.8.tar.gz。然后在服务器中存放redis包的路径下执行tar –vxf redis-4.0.8.tar.gz&#xff08;这里对应下载的包&#xff09;&#xff0c;解压redis后,cd 进入 redis-4.0.8&#xff08;…

图解安装CentOS 6.6

以下是在虚拟机上安装CentOS 6.6的过程。一、安装文件:CentOS-6.6-x86_64-bin-DVD.iso二、安装步骤# 虚拟机的配置这里省略&#xff0c;在百度上有很多帖子可以参考。开启虚拟机进入安装界面&#xff0c;如下图所示选择第一个选项&#xff0c;按Enter安装程序加载完后&#xff…

一幅长文细学Vue(三)——组件基础(上)

3 组件基础&#xff08;上&#xff09; 摘要 ​ 在本文中&#xff0c;我们将学习什么是SPA&#xff0c;以及Vue中组件的基本使用。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附上部分演示代码&#xff0c;main.js文件的代码通常不贴出&#xff…

综合练习:词频统计

下载一首英文的歌词或文章 将所有,.&#xff1f;&#xff01;’:等分隔符全部替换为空格 将所有大写转换为小写 生成单词列表 fopen(news.txt,r) newsf.read() f.close() sep,.!"?: for c in sep:newsnews.replace(c, )wordListnews.lower().split()for w in wordList:pr…

linux中fcntl()、lockf、flock的区别

fcntl()、lockf、flock的区别 ——lvyilong316 这三个函数的作用都是给文件加锁&#xff0c;那它们有什么区别呢&#xff1f;首先flock和fcntl是系统调用&#xff0c;而lockf是库函数。lockf实际上是fcntl的封装&#xff0c;所以lockf和fcntl的底层实现是一样的&#xff0c;对文…

iOS开发拓展篇—音频处理(音乐播放器6)

一、图片处理 说明&#xff1a; Aspect表示按照原来的宽高比进行缩放。 Aspectfit表示按照原来的宽高比缩放&#xff0c;要求看到全部图片&#xff0c;后果是不能完全覆盖窗口&#xff0c;会留有空白。 Aspectfill表示按照原来的宽高比缩放&#xff0c;但只能看到部分图片。引发…

词频统计预处理之综合练习

下载一首英文的歌词或文章 news , 生成词频统计 sep,.;:"" for c in sep:newsnews.replace(c, )wordlistnews.lower().split()wordDict{} for w in wordlist:wordDict[w]wordDict.get(w,0)1wordSetset(wordlist) for w in wordSet:wordDict[w]wordlist.count(w)f…

一幅长文细学Vue(五)——组件高级(上)

5 组件高级&#xff08;上&#xff09; 摘要 ​ 在本文中&#xff0c;我们会详细讨论watch侦听器的基本使用&#xff0c;并且了解vue中常用的生命周期函数、实现组件之间的数据共享&#xff0c;最后学习如何在vue3.x项目中全局配置axios。 声明&#xff1a;为了文章的清爽性&am…

流行的编程语言及其趋势

转&#xff1a;StackOverflow上的编程趋势 http://www.csdn.net/article/2013-07-08/2816144-StackOverflow-Programming-Trends 摘要&#xff1a;相信每个程序员都知道StackOverflow问答网站&#xff0c;本文作者dodgy_coder通过StackExchange Data Explorer Query收集了该网站…

CentOS7.0 安装 tomcat-9.0

2019独角兽企业重金招聘Python工程师标准>>> 1、解压 # tar -zxvf apache-tomcat-9.0.0.M4.tar.gz -C /opt/usr/local 改个名字好以后操作&#xff1a; # mv apache-tomcat-9.0.0.M4.tar.gz tomcat 2、启动&停止 # /opt/usr/local/tomcat/bin/start…

一幅长文细学华为MRS大数据开发(四)——HBase

4 HBase 摘要&#xff1a;HBase是一种非关系型数据库&#xff0c;它是基于谷歌BigTable的开源实现&#xff0c;和BigTable一样&#xff0c;支持大规模海量数据的存储&#xff0c;对于分布式并发数据处理的效率极高&#xff0c;易于扩展且支持动态伸缩&#xff0c;适用于廉价设备…

AOP技术基础

1、引言2、AOP技术基础 3、Java平台AOP技术研究4、.Net平台AOP技术研究2.1 AOP技术起源 AOP技术的诞生并不算晚&#xff0c;早在1990年开始&#xff0c;来自Xerox Palo Alto Research Lab&#xff08;即PARC&#xff09;的研究人员就对面向对象思想的局限性进行了分析。他们研…

TCP 协议的三次握手、四次分手

详细描述了 TCP 协议的连接和关闭的整个过程。解释了为什么 TCP 协议是面向连接的、可靠的数据传输协议。 TCP 在互联网上之间的通信交流&#xff0c;一般是基于 TCP (Transmission Control Protocol&#xff0c;传输控制协议) 或者 UDP (User Datagram Protocol&#xff0c;用…

[Bzoj4182]Shopping(点分治)(树上背包)(单调队列优化多重背包)

4182: Shopping Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 374 Solved: 130[Submit][Status][Discuss]Description 马上就是小苗的生日了&#xff0c;为了给小苗准备礼物&#xff0c;小葱兴冲冲地来到了商店街。商店街有n个商店&#xff0c;并且它们之间的道路构成了一…

Tiny框架2.0版火热推出

方法论 方法论决定了可以达到的高度 方法论&#xff0c;就是人们认识世界、改造世界的根本方法。 它是人们用什么样的方式、方法来观察事物和处理问题。概括地说&#xff0c;世界观主要解决世界“是什么”的问题&#xff0c;方法论主要解决“怎么办”的问题。 方法论是一种以解…

Java--Socket通信

下面内容是Java开发内容的高级知识点&#xff0c;需要对Java中的面向对象、IO、多线程、以及网络相关知识有一定的基础。(知识永远都有深度&#xff0c;本章节长期更新内容) 1、网络基础知识 网络通信的条件&#xff1a;1、两个通信的端都要有各自的IP地址作为唯一标识&#xf…