1022 D进制的A+B (20point(s))
输入两个非负 10 进制整数 A 和 B (≤230−1),输出 A+B 的 D (1<D≤10)进制数。
输入格式:
输入在一行中依次给出 3 个整数 A、B 和 D。
输出格式:
输出 A+B 的 D 进制数。
输入样例:
123 456 8
输出样例:
1103
关于进制转换可以看看这一篇文章:进制转换问题总结
本题代码如下:
//
// Created by LittleCat on 2020/2/2.
//
#include <cstdio>
int main() {
int a, b, d;
scanf("%d %d %d", &a, &b, &d);
int x = a + b;
int ans[100] = {0};
int count = 0;
do {
ans[count++] = x % d;
x = x / d;
} while (x != 0);
/* 从高位到低位输出答案 */
for(int i = count - 1; i >= 0; i--)
printf("%d", ans[i]);
printf("\n");
return 0;
}
主要要注意:
使用do while循环而不是while循环,不然当待转换数为0时不会给数组进行赋值而出错。
end
欢迎关注个人公众号“ 鸡翅编程 ”,这里是认真且乖巧的码农一枚。
---- 做最乖巧的博客er,做最扎实的程序员 ----
旨在用心写好每一篇文章,平常会把笔记汇总成推送更新~