反向计算

本文关键字:计算 | 更新日期: 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编码为字节数组,然后从数组中对其进行解码。