3820. i-1 进制(Easy)

Hard普通指针位运算一维数组

时间限制:2000 ms

内存限制:512 MiB

题面

在采用进位计数的数字系统中,如果使用的数码依次为 0,1,2,,R10,1,2,\ldots,R-1,总共 RR 个数码,则称其为基 RR 数制或 RR 进制。RR 称为该数制的“基数”(RadixRadix),例如,十进制的基数是 1010(数码为: 0,1,2,,90,1,2,\ldots,9),二进制的基数是 22(数码为: 0,10,1),八进制的基数是 88(数码为: 0,1,2,,70,1,2,\ldots,7)。

现有一种特殊的按位计数系统,该系统采用的基数为复数 1+i-1+i (其中 ii 表示 1\sqrt{-1} )。在1+i-1+i 进制系统中,所有“复数整数”(实部和虚部都为整数的复数,这种复数在数学上称为高斯整数)都可以表示成一个“数”,该“数”只含有 0,10,1 两个数码,不需要正负符号或其他常规手段,而且每个“复数整数”只有唯一一种表示方法。例如:整数 221+i-1+i 进制表示出来是1100

任意一个“复数整数” a+bia+bia,ba,b 均为整数) 可采用如下算法转换为1+i-1+i 进制表示:

1、a+bia+bi 除以 1+i-1+i 得到商 qq 和余数 rr ,商qq 也为“复数整数”,余数 rr0011

​ 令 q=qr+qiiq=q_r+q_iiqrq_rqiq_i 均为整数,分别表示商 qq 的实部与虚部),

q,rq,r 必满足下式: a+bi=(qr+qii)(1+i)+r a+bi= (q_r+q_ii)(-1+i) + r

​ 如果 a,ba,b 均为偶数或均为奇数,则令 rr00

​ 此外,如果 a,ba,b 一奇一偶,则令 rr11

2、重复第一步用商 qq 除以 1+i-1+i 记录下余数 rr,直到商为 00,运算过程结束。

3、从下往上读取余数,就可得到 “复数整数” a+bia+bi1+i-1+i 进制表示。

例如:整数 2=2+0i2 = 2+ 0i 的运算过程:

整数 22 的实部和虚部都是偶数,所以余数为 0021+i=(1i)\frac{2}{-1+i} =(-1-i)00

1i-1-i 的实部和虚部均为奇数,所以余数为 001i1+i=i\frac{-1-i}{-1+i}=i00

ii 的实部为偶数,虚部为奇数,所以余数为 11i1+i=1\frac{i}{-1+i}=111

11 的实部为奇数,虚部为偶数,所以余数为 1111+i=0\frac{1}{-1+i}=011

商为 00,运算结束,从下往上读取,得到整数 221+i-1+i进制表示为1100

下表列出了 1+i-1+i 进制的位串00001111对应的十进制下的“复数整数”。

1+i-1+i 进制十进制下的复数整数
000
111
101+i-1+i
11ii
1002i-2i
10112i1-2i
1101i-1-i
111i-i
10002+2i2+2i
10013+2i3+2i
10101+3i1+3i
10112+3i2+3i
110022
110133
11101+i1+i
11112+i2+i

输入一个 1+i -1+i 进制下的数(为了简化,我们将0,1位串用一个十六进制整数表示),输出其对应的十进制下的“复数整数” a+bia+bi

输入格式

在一行中输入一个 1+i -1+i 进制下的数(十六进制表示,使用 09 以及大写 AF)。

  • 35% 的数据保证答案的 a,b100|a|, |b| \leq 100
  • 58% 的数据保证答案的 a,b2 147 483 647|a|, |b| \leq 2~147~483~647
  • 100% 的数据保证答案的 a,b9 223 372 036 854 775 807|a|, |b| \leq 9~223~372~036~854~775~807.

输出格式

在一行中输出对应的十进制下的“复数整数” a+bia+bia,ba,b均为整数),省略的情况与正常书写复数时一致,请参考上面的表格以及样例。

样例

输入

0x21

输出

5-4i

输入

0x2

输出

-1+i

输入

0x1C

输出

-2

输入

0x9

输出

3+2i