算术编码的C++实现(共5页).doc
《算术编码的C++实现(共5页).doc》由会员分享,可在线阅读,更多相关《算术编码的C++实现(共5页).doc(5页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上算术编码的C+实现#include #include #include #include using namespace std;#define N 50 /输入的字符应该不超过50个struct L /结构用于求各字符及其概率char ch; /存储出现的字符(不重复) int num; /存储字符出现的次数double f;/存储字符的概率 ;/显示信息void disp();/求概率函数,输入:字符串;输出:字符数组、字符的概率数组;返回:数组长度;int proba(string str,char c,long double p,int count);/求概率
2、的辅助函数int search(vector arch,char,int n);/编码函数,输入:字符串,字符数组,概率数组,以及数组长度;输出:编码结果long double bma(char c,long double p,string str,int number,int size);/译码函数,输入:编码结果,字符串,字符数组,概率数组,以及它们的长度;输出:字符串/该函数可以用于检测编码是否正确void yma(string str,char c,long double p, int number,int size,long double input);int main()strin
3、g str; /输入要编码的String类型字符串int number=0,size=0; /number-字符串中不重复的字符个数;size-字符串长度char cN; /用于存储不重复的字符 long double pN,output; /pN-不重复字符的概率,output-编码结果disp();cout输入要编码的字符串:;getline(cin,str); /输入要编码的字符串size=str.length(); /字符串长度number=proba(str,c,p,size);/调用求概率函数,返回不重复字符的个数cout.setf(ios:fixed); /“魔法配方”规定了小数
4、部分的个数cout.setf(ios:showpoint); /在此规定编码结果的小数部分有十个cout.precision(10);output=bma( c, p, str, number, size);/调用编码函数,返回编码结果yma(str,c, p, number, size, output); /调用译码函数,输出要编码的字符串, /以验证编码是否正确return 0;/显示信息void disp()coutendl;cout*算术编码*n;cout*作者:heiness*n;coutendl;cout此程序只需要输入要编码的字符串,不需要输入字符概率n; coutendl;/求
5、概率函数int proba(string str,char c,long double p, int count) cout.setf(ios:fixed); /“魔法配方”规定了小数部分位数为三位cout.setf(ios:showpoint);cout.precision(3);vectorpt; /定义了结构类型的向量,用于同时存储不重复的字符和其概率 L temp; /结构类型的变量temp.ch = str0; /暂存字符串的第一个字符,它的个数暂设为1temp.num=1; temp.f=0.0;pt.push_back(temp); /将该字符及其个数压入向量 for (int
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 算术 编码 C+ 实现
限制150内