输入两个非负10进制整数A和B(<=230-1),输出A+B的D (1 < D <= 10)进制数。
输入格式:
输入在一行中依次给出3个整数A、B和D。
输出格式:
输出A+B的D进制数。
输入样例:123 456 8
输出样例:
1033
注意:有一个case是0和0,如果不注意的话,这个测试点就很难过去。
代码如下:
#include<iostream>
#include<string>
#include<vector>
#include<map>
using namespace std;
map<int, char> m;
string transform(long long n,int d)
{
string s="";
if (n == 0)
return s = "0";
for (int x = n; x != 0; x = x / d)
{
s = m[x%d] + s;
}
return s;
}
int main()
{
#ifdef ONLINE_JUDGE
#else
freopen("D:\\in.txt", "r", stdin);
freopen("D:\\out.txt", "w", stdout);
#endif
long long a, b, d;
for (int i = 0; i < 10; i++)
{
m[i] = '0' + i;
}
while (cin >> a >> b >> d)
{
if (d == 10)
cout << a + b << endl;
else
cout << transform(a + b, d) << endl;
}
return 0;
}
别人的代码,可以参考一下:
#include<cstdio>
#define MAX 1000
using namespace std;
int main(int argc,char *argv[])
{
long long a,b,d;
long long i,temp,sum;
int array[MAX];
scanf("%lld%lld%lld",&a,&b,&d);
sum=a+b;
i=0;
if(sum==0)
printf("0");
else
{
while(sum)
{
array[i]=sum%d;
sum=sum/d;
i++;
}
i--;
for(;i>=0;i--)
printf("%d",array[i]);
}
printf("\n");
return 0;
}