进制转换

【原创】  

今天来说说进制转换,经常熟悉的进制无外乎就是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("\n");
17     }
18  return 0;
19 }
posted @ 2017-03-03 10:30  小小范同学  阅读(625)  评论(1编辑  收藏  举报