杭电oj——有关进制的问题 (1)

来源:互联网 发布:centos phpbrew 编辑:程序博客网 时间:2024/05/04 15:44
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;}


0 0
原创粉丝点击