您的位置:首页 > 其它

PAT(Basic Level) 1022 D进制的A+B (20)

2014-03-07 16:41 513 查看
输入两个非负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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: