编程介的小学生 2016-12-14 09:57 采纳率: 20.5%
浏览 941
已采纳

Leaky Cryptography

Description

The ACM ICPC judges are very careful about not leaking their problems, and all communi-cations are encrypted. However, one does sometimes make mistakes, like using too weak an encryption scheme. Here is an example of that.
The encryption chosen was very simple: encrypt each chunk of the input by flipping some bits according to a shared key. To provide reasonable security, the size of both chunk and key is 32 bits.
That is, suppose the input was a sequence of m 32-bit integers.
N1 N2 N3 ... Nm
After encoding with the key K it becomes the following sequence of m 32-bit integers.
(N1∧K) (N2∧K) (N3∧K) ... (Nm∧K)
where (a∧b) is the bitwise exclusive or of a and b.
Exclusive or is the logical operator which is 1 when only one of its operands is 1, and 0 otherwise.
Here is its definition for 1-bit integers.
0 ♁ 0 = 0 0 ♁ 1 = 1

1 ♁ 0 = 1 1 ♁ 1 = 0

As you can see, it is identical to addition modulo 2. For two 32-bit integers a and b, their bitwise exclusive or a ∧ b is defined as follows, using their binary representations, composed of 0's and 1's.
a ∧ b = a31...a1a0∧b31...b1b0 = c31...c1c0
where
ci = ai♁bi (i = 0, 1, ... , 31).
For instance, using binary notation, 11010110 ∧ 01010101 = 10100011, or using hexadecimal, d6 ∧ 55 = a3.
Since this kind of encryption is notoriously weak to statistical attacks, the message has to be compressed in advance, so that it has no statistical regularity. We suppose that N1 N2 . . .Nm is already in compressed form.
However, the trouble is that the compression algorithm itself introduces some form of regularity: after every 8 integers of compressed data, it inserts a checksum, the sum of these integers. That is, in the above input, N9 = N1 +...+ N8, where additions are modulo 232.
Luckily, you could intercept a communication between the judges. Maybe it contains a problem for the finals!
As you are very clever, you have certainly seen that you can easily find the lowest bit of the key, denoted by K0. On the one hand, if K0 = 1, then after encoding, the lowest bit of Σ1<=i<=8Ni∧K is unchanged, as K0 is added an even number of times, but the lowest bit of N9∧K is changed, so they shall differ. On the other hand, if K0 = 0, then after encoding, the lowest bit of Σ1<=i<=8Ni∧K shall still be identical to the lowest bit of N9∧K, as they do not change. For instance, if the lowest bits after encoding are 1 1 1 1 1 1 1 1 1 then K0 must be 1, but if
they are 1 1 1 1 1 1 1 0 1 then K0 must be 0.
So far, so good. Can you do better?
You should find the key used for encoding.
Input

The input starts with a line containing only a positive integer S, indicating the number of datasets in the input. S is no more than 1000.
It is followed by S datasets. Each dataset is composed of nine 32-bit integers corresponding to the first nine chunks of a communication. They are written in hexadecimal notation, using digits 0' to9' and lowercase letters a' tof', and with no leading zeros. They are separated by a space or a newline. Each dataset is ended by a newline.
Output

For each dataset you should output the key used for encoding. Each key shall appear alone on its line, and be written in hexadecimal notation, using digits 0' to9' and lowercase letters a' tof', and with no leading zeros.
Sample Input

8
1 1 1 1 1 1 1 1 8
3 2 3 2 3 2 3 2 6
3 4 4 7 7 b a 2 2e
e1 13 ce 28 ca 6 ab 46 a6d
b08 49e2 6128 f27 8cf2 bc50 7380 7fe1 723b
4eba eb4 a352 fd14 6ac1 eed1 dd06 bb83 392bc
ef593c08 847e522f 74c02b9c 26f3a4e1 e2720a01 6fe66007
7a4e96ad 6ee5cef6 3853cd88
60202fb8 757d6d66 9c3a9525 fbcd7983 82b9571c ddc54bab 853e52da
22047c88 e5524401
Sample Output

0
2
6
1c6
4924afc7
ffff95c5
546991d
901c4a16

  • 写回答

1条回答 默认 最新

  • threenewbee 2016-12-14 10:04
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器