题面描述
小 A 想给小 B 传输一串长度为 n 的二进制数 a1a2...an,但由于外界环境的干扰,传输的二进制数的某一位可能发生改变,为了应对这个问题,小 A 学习了海明码。
海明码(Hamming code)是一种线性误差更正码,由理查德·海明(Richard Hamming)在1950年发明。它能够检测和纠正单一比特的错误。海明码通过在数据位之间插入额外的校验位来实现这种错误检测和更正的功能。
设 t=⌈log2(n+1)⌉ ,则小 A 会在这 n 位二进制码的后面补上 t+1 位 b0b1...bt−1c 。
其中 bi 的值为所有二进制第 i 位为 1 的数 j 的 aj 异或和。例如 n=6 ,则 b1=a2⊕a3⊕a6 ,而 c 为所有 ai 的异或和,即 c=a1⊕a2⊕...⊕an。
这样将小A 将 a1a2...anb0b1...bt−1c 传输给小 B ,那么小B 得到的是 A1A2...AnB0B1...Bt−1C,小 B 就可以通过 Bi 和 C 的值来判断他收到的 A1A2...An 和 a1a2...an 相比,是否有某一位发生了改变,如果发生了那改变的是哪一位?
现在小 B 希望得到 a0a1...an−1 到底是什么,请你帮帮他!
小 A 贴心的为小 B 提供了一个判断过程:
- 若 C⊕A1⊕A2⊕...⊕An=0 ,则说明 a1a2...an=A1A2...An 。
- 若 C⊕A1⊕A2⊕...⊕An=1 ,按接下来的步骤处理:
- 设一个未知数 f 。
- 对于每一个 i ,我们设 di 的值为所有二进制第 i 位为 1 的数 j 的 Aj 异或和.
- 若 di⊕Bi=1 ,我们就令 f 二进制的第 i 位是 1 。
- 若 di⊕Bi=0 ,我们就令 f 二进制的第 i 位是 0 。
- 最后若 f=0 则 a1a2...an=A1A2...An 。
- 否则对于所有 i=f,ai=Ai 而 Af=af⊕1 。
输入格式
第 1 行包含一个正整数 n,表示二进制数的位数。
第 2 行为 n+⌈log2n⌉+1 位的 01 字符串,表示小 B 收到的 $A_0A_1...A_{n-1}B_0B_1...B_{\lceil \log_2n\rceil-1}C$ 。
输出格式
输出一行长度为 n 的 01 串,表示 a0a1...an−1。
样例一
7
11100010101
1110101
样例解释
因为 A1⊕A2⊕...⊕A7⊕C=1 ,且
- A1⊕A3⊕A5⊕A7⊕b0=1
- A2⊕A3⊕A6⊕A7⊕b1=0
- A4⊕A5⊕A6⊕A7⊕b2=1
所以 f=5 ,所以 a0a1...an−1=1110101。
数据范围
对于所有数据 n≤107 ,保证数据合法。