输入两个非负 10 进制整数 A 和 B (≤230−1),输出 A+B 的 D (1<D≤10)进制数。
输入格式:
输入在一行中依次给出 3 个整数 A、B 和 D。
输出格式:
输出 A+B 的 D 进制数。
输入样例:
123 456 8
输出样例:
1103
关键之处:
- 动手写一下怎么转换进制的,翻译成C语言就行。
代码:
#include <stdio.h>
#define MAXN 100 //随便设的数,够装sum就行。
int main(void) {
long int A, B, sum;
int D, i, r[MAXN] = {0}, k;
scanf("%ld%ld%d", &A, &B, &D);
sum = A + B; //算出十进制的和。
if ( sum ) { //和不为零的情况,进制转换。
k = 0;
while ( sum ) {
r[k++] = sum % D; //对D求余数,并保存到r[]中。
sum = sum / D; //砍掉一位。
}
for ( i = k-1; i >= 0; i-- )
printf("%d", r[i]); //余数倒着输出就是转换结果。
}
else printf("0"); //和为零,直接输出0.
return 0;
}