[英]Inverse Calculation
我想从编码字节中获取t
编码
byte enc(int t, int k)
{
k %= 8;
return (byte)(((t << k) | (t >> (8 - k))) & 0xff);
}
试过了
(65132 & 0xff) | ~0xff
结果
-148
想
int dec(byte enc, int k)
return t; // how to calculate t?
如果要编写解码函数,则需要知道编码函数的工作方式。
在这种情况下,它占用k
个最右边的字节并将其放在尾部。
例如1101
将被编码为0111
。
因此,如果要解码,则需要执行相反的操作。
public static byte dec(byte enc, int k)
{
k %= 8;
return (byte)((enc >> k) | (enc << (8 - k)));
}
但是,如果您将int
编码为byte
,则可能会丢失一些信息。
例如,您无法对足够大的数字(例如1234567890
进行编码以将其byte
然后解码。
但是您可以将int
编码为字节数组,然后从array对其进行解码。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.