早教吧作业答案频道 -->其他-->
算术编码的解码问题假设我源码是ABADCAEABE那么我通过算术编码得到的是0.18442815,再用0.18442815解码,就可以得到源码了.这是因为0.18442815很短.假设0.18442815后面还有1000位,那么我就不能用一个doubl
题目详情
算术编码的解码问题
假设我源码是ABADCAEABE那么我通过算术编码得到的是0.18442815,再用0.18442815解码,就可以得到源码了.这是因为0.18442815很短.假设0.18442815后面还有1000位,那么我就不能用一个double型来存它了,我把它小数点后面的数用相应的十六进制数来表示(2F36BA……)那么解码的时候我也不可能一次计算得到0.18442815…….所以我只能一次读一个,比如先读2,再读F,再读3……
但是每次新添加进来的数都要除以之前所有的range的值,就会有溢出的问题.
或者谁有编解码的程序能传给我啊,或者告诉我链接(不要那种输入很短的,不要手动输入的,要可以读入文件,输出文件,无损编码的)
假设我源码是ABADCAEABE那么我通过算术编码得到的是0.18442815,再用0.18442815解码,就可以得到源码了.这是因为0.18442815很短.假设0.18442815后面还有1000位,那么我就不能用一个double型来存它了,我把它小数点后面的数用相应的十六进制数来表示(2F36BA……)那么解码的时候我也不可能一次计算得到0.18442815…….所以我只能一次读一个,比如先读2,再读F,再读3……
但是每次新添加进来的数都要除以之前所有的range的值,就会有溢出的问题.
或者谁有编解码的程序能传给我啊,或者告诉我链接(不要那种输入很短的,不要手动输入的,要可以读入文件,输出文件,无损编码的)
▼优质解答
答案和解析
给你几点思路:
1:所谓的编码解码可以约看于压缩和解压缩,无论是哪种编码方式,都不可能是对所有字串或者关键串全部通过一组运算来得到key的?首先这已经是一种,无论从运算量、时间量、空间量都不允许这样做,好比如你要求计算机计算
两位数乘两位数,这样的要求还是绝对可以完成的,但是要求几千位数同时乘几千位数,那计算机怎么乘?怎么运算?现在的cpu包括所谓4核的芯,都不可能出现能实现这个要求的指令,而答案必然是分组分部计算,不可能同时运算的.
2:结合第一点的结论,也就是你再算术编码的时候的运算公式是什么,然后你得人为的把它拆分,让字串能每读取一部分的串通过运算累加后也能得到结果.
通过这一步骤你不需要全部读完所有的字串,只需要读取一部分运算,再读部分运算,从而累加结果.
3:无论是字串还是key都是以char[]来存储的,因为能开辟的空间较大,同时也是有限的,看你的堆栈设置,当然一般来说完全够用了,你要是在运行中还出现溢出,那么请你回头考虑的你的算法和解码过程了
1:所谓的编码解码可以约看于压缩和解压缩,无论是哪种编码方式,都不可能是对所有字串或者关键串全部通过一组运算来得到key的?首先这已经是一种,无论从运算量、时间量、空间量都不允许这样做,好比如你要求计算机计算
两位数乘两位数,这样的要求还是绝对可以完成的,但是要求几千位数同时乘几千位数,那计算机怎么乘?怎么运算?现在的cpu包括所谓4核的芯,都不可能出现能实现这个要求的指令,而答案必然是分组分部计算,不可能同时运算的.
2:结合第一点的结论,也就是你再算术编码的时候的运算公式是什么,然后你得人为的把它拆分,让字串能每读取一部分的串通过运算累加后也能得到结果.
通过这一步骤你不需要全部读完所有的字串,只需要读取一部分运算,再读部分运算,从而累加结果.
3:无论是字串还是key都是以char[]来存储的,因为能开辟的空间较大,同时也是有限的,看你的堆栈设置,当然一般来说完全够用了,你要是在运行中还出现溢出,那么请你回头考虑的你的算法和解码过程了
看了 算术编码的解码问题假设我源码...的网友还看了以下:
齐次微积分方程后面得到等式(1-u)/(1+u²)du=dx/x然后我积分得到arctanu-ln√ 2020-03-30 …
”忘”字用五笔怎么打出?他不是分3个字根吗?打3下加上一个空格应该出来的,怎么却出不来.而正确的是 2020-05-17 …
3个数字可以组成多少个号码!我的密码箱子忘记密码了!他是3个号组成的!请问高人3个数字可以组成多少 2020-07-18 …
一道高数题!已知函数y=f(x)有二阶连续导数,且曲线有拐点(x.,f(x.)),则lim(u→0 2020-07-18 …
先对照摩斯密码表,得到419441814163s对照手机键盘密码(每两个数字表示一个字母),得到g 2020-07-23 …
微分方程y'=(y/x)^2+y/x的通解,答案是y(x+c)+x=0令u=y/x,y‘=u+xu' 2020-11-01 …
小王问班主任仇老师家的电话号码是多少,仇老师说想知道我家的电话号码,你得动点脑筋,接着又说,我家的电 2020-11-08 …
小松鼠有个密码箱,但忘记了密码.它突然想起来密码好像跟它的年龄、生日有关,而它自己今年刚好10岁,生 2020-12-17 …
家里的电话号码,我只记得前两位号码是63,后面的六位号码忘了,后面六位号码由六个数组成(没有0),其 2020-12-27 …
用分解质因数的方法得到质因数了,怎么求出这个数的所有因数比如说一个数分解得到质因数是23571113 2021-01-22 …