题目描述:
输入两个非负 10 进制整数 A 和 B (≤2^30 −1),输出 A+B 的 D (1<D≤10)进制数。
输入格式:
输入在一行中依次给出 3 个整数 A、B 和 D。
输出格式:
输出 A+B 的 D 进制数。
输入样例:
123 456 8
输出样例:
1103
本人AC代码:
// PAT乙级
// PAT_1022_System
// 对10进制的数据家和结果进行进制转换
# include <stdio.h>
# define Max 32
int main(void)
{
long A, B, Sum;
int i, D;
int System[Max+1]; // 记录转换之后的数据
// 输入数据
scanf("%ld",&A);
scanf("%ld",&B);
scanf("%d",&D);
// 计算A+B
Sum = A+B;
if (Sum == 0)
{
printf("0");
return 0;
}
// 进制转换
for (i=Max; i>=0; i--)
{
System[i] = -1;
}
i=0;
while (Sum != 0)
{
System[i++] = Sum%D;
Sum /= D;
}
for (i=Max; i>=0; i--)
{
if (System[i] != -1)
printf("%d",System[i]);
}
return 0;
}
RRR