ACM题目————小A的计算器

Description

以往的操作系统内部的数据表示都是二进制方式,小A新写了一个操作系统,系统内部的数据表示为26进制,其中0-25分别由a-z表示。
 现在小A要在这个操作系统上实现一个计算器,这个计算器要能实现26进制数的加法运算。你能帮小A实现这个计算器吗?

Input

输入的第一行包括一个整数N(1<=N<=100)。

接下来的N行每行包括两个26进制数x和y,它们之间用空格隔开,每个数的位数最多为10位,我们可以保证相加的结果的位数最多也是10位。每个数会用
小A所设计的操作系统中的表示方法来表示,如:bsadfasdf。即每个数的各个位均由26个小写字母a-z中的一个来表示。

Output

输出x和y相加后的结果,结果也要用题目中描述的26进制数来表示。

Sample Input

4
ba cd
c b
b c
ba c

Sample Output

dd
d
d
bc

Hint

1.注意,26进制数的表示方式和10进制数一样,最右边是最低位。
 2.输入的两个数有可能有前缀0,即a,请在程序中进行处理。
 3.结果中如果出现前缀0,请自动滤除,除非结果就是0。如:结果为ab时,要输出b,因为a表示0。

用的蠢方法解决,用的方法和大数的加减法差不多。

#include <stdio.h>
#include <string.h> #define N 100
#define M 10 int main(void)
{
int n, i, j;
char a[M+], b[M+];
int lena, lenb; while (scanf("%d", &n) != EOF)
{
for(j=; j<n; j++)
{
scanf("%s%s", a, b); lena = strlen(a);
for (i=M-; i>=M-lena; i--)
a[i] = a[i-M+lena];
for (i=; i<M-lena; i++)
a[i] = 'a';
a[M] = '\0'; lenb = strlen(b);
for (i=M-; i>=M-lenb; i--)
b[i] = b[i-M+lenb];
for (i=; i<M-lenb; i++)
b[i] = 'a';
b[M] = '\0'; for (i=M-; i>=; i--)
{
int tmp = a[i] + b[i]-'a';
if (tmp > 'z')
{
a[i-] += ;
a[i] = (char)(tmp - );
}
else
a[i] = tmp;
} for (i=; i<M; i++)
{
if (a[i] != 'a')
break;
}
if (i == M)
printf("a\n");
else
printf("%s\n", a+i);
} break;
} return ;
}
上一篇:noj算法 迷宫问题 回溯法


下一篇:Python框架