1022. D进制的A+B (20)

题目描述

输入两个非负10进制整数A和B(<=230-1),输出A+B的D (1 < D <= 10)进制数。

输入格式:

输入在一行中依次给出3个整数A、B和D。

输出格式:

输出A+B的D进制数。

输入样例:

123 456 8

输出样例:

1103

提交代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#include <iostream>
using namespace std;
int main()
{
int A, B, D;
int i, sum;
string s;

cin >> A >> B >> D;
sum = A + B;
if (sum == 0)
cout << '0' << endl;
else {
while (sum != 0) {
s += sum % D + '0';
sum = sum / D;
}
for (i = s.length() - 1; i >=0; i--) {
cout << s[i];
}
cout << endl;
}

return 0;
}

个人思考

估计这里有个输入是A、B都是零的,有个样例一直过不了,直到加上对和为零的特殊处理。说明PAT的测试样例考虑得还是有点周全的,以后在自己测试的时候也要多思考一下,不能只考虑上界不考虑下界之类的。