反向计算
本文关键字:计算 | 更新日期: 2023-09-27 18:36:24
我想从编码字节中获取 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
编码为字节数组,然后从数组中对其进行解码。