1720:
A+B Coming
问题:16进制输入,10进制输出
C语言提供了一个利器 %x(或%X)--------------读入16进制整数
#include <iostream>
using namespace std;
int main()
{
int a,b;
while(scanf("%x%x",&a,&b)!=EOF)
{
printf("%d\n",a+b);
}
return 0;
}
1877:
又一版 A+B
问题:输入m,A,B。输出A+B的m进制
思路:除m取余,倒过来输出,一定要考虑A+B=0,输出0的情况
#include <iostream>
#include <vector>
using namespace std;
int main()
{
int m,a,b,i,s;
vector<int> v;
while(scanf("%d%d%d",&m,&a,&b)!=EOF &&(m!=0))
{
s=a+b;
if(s==0)
{
cout<<"0"<<endl;
continue;
}
v.clear();
while(s!=0)
{
v.push_back(s%m);
s/=m;
}
for(i=v.size()-1;i>=0;i--)
{
cout<<v[i];
}
cout<<endl;
}
return 0;
}
2031:
进制转换
problem
输入一个十进制数N,将它转换成R进制数输出。
Input
输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=16, R<>10)。
Output
为每个测试实例输出转换后的数,每个输出占一行。如果R大于10,则对应的数字规则参考16进制(比如,10用A表示,等等)。
解题思路:
如果输入的十进制数为负数,就先按正数来算,再在结果前加一个负号。如果转化的进制大于十,就用C语言的利器,%X转化(%x转化为a,b......)输出
#include<iostream>
#include <cmath>
#include<vector>
using namespace std;
int main()
{
int a,m,i;
vector<int> vec;
while(cin>>a>>m)
{
if(a<0)
{
cout<<"-";
}
a=abs(a);
vec.clear();
while(a!=0)
{
vec.push_back(a%m);
a/=m;
}
for(i=vec.size()-1;i>=0;i--)
{
if(vec[i]>=10)
{
printf("%X",vec[i]);
}
else
{
cout<<vec[i];
}
}
cout<<endl;
}
return 0;
}