【原创】
今天来说说进制转换,经常熟悉的进制无外乎就是2,8,10,16,那么这些进制之间如何转换呢,我们比较熟悉的转换便是10进制和其他进制数之间的转换,那么我们以10进制为媒介,进行相应的转换,举个例子,将8进制x转为2进制,我只需要将x先转为10进制y,然后再10进制y转为2进制z,如下面的例子;
输入: 输入格式:测试输入包含若干测试用例。每个测试用例占一行,给出m和A,B的值。 当m为0时输入结束。 输出: 输出格式:每个测试用例的输出占一行,输出A+B的m进制数。 样例输入: 8 1300 48 2 1 7 0 样例输出: 2504 1000
这里,我们只需要将A和B相加,然后再转换,代码如下:
注意:这里只是交代了思想,之后的一篇文章全面的进行了各种进制之间的转换:http://www.cnblogs.com/numen-fan/p/6495650.html
1 #include<stdio.h> 2 int main(){ 3 long long a,b;//防止溢出; 4 int m; 5 while (scanf("%d",&m)!=EOF&&m!=0) { 6 scanf("%lld%lld",&a,&b); 7 a = a+b; 8 int ans[50],size = 0; 9 do{ 10 ans[size++] = a%m; 11 a/=m; 12 }while(a!=0);//采用这样的结构,可以解决a,b为0的情况, 13 for(int i = size-1;i>=0;i--){//是从高位开始输出的; 14 printf("%d",ans[i]); 15 } 16 printf(" "); 17 } 18 return 0; 19 }