输入两个非负10进制整数A和B(<=2^30-1),输出A+B的D (1 < D <= 10)进制数。
输入格式:
输入在一行中依次给出3个整数A、B和D。
输出格式:
输出A+B的D进制数。
输入样例:
123 456 8
输出样例:
1103
分析:设t = A + B,将每一次t % d的结果保存在int类型的数组s中,然后将t / d,直到 t 等于 0为止,此时s中保存的就是 t 在 D 进制下每一位的结果的倒序,最后倒序输出s数组即可~
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
#include <iostream> using namespace std; int main() { int a, b, d; cin >> a >> b >> d; int t = a + b; if (t == 0) { cout << 0; return 0; } int s[100]; int i = 0; while (t != 0) { s[i++] = t % d; t = t / d; } for (int j = i - 1; j >= 0; j--) cout << s[j]; return 0; } |
❤ 点击这里 -> 订阅《PAT | 蓝桥 | LeetCode学习路径 & 刷题经验》by 柳婼