sicily 6446. base conversion

Description

 编写一个程序,把一个非负的十进制数转换为任意base(2<=base<=16)进制的数。

Input

 输入包括多组测试用例,通过EOF结束。

每组测试用例包含两个数,以空格隔开,第一个为需要转换的十进制数,第二个为转换的进制。

Output

 每组测试用例输出一行,为转换后的数的表示,如果转换后的数的某个数位上的数大于等于10,则分别用A, B, C……来表示。

 

考完机试做了下法师班上的题,发现比我们的作业实用+科学很多啊,囧……

一直想写一个这个不过各种拖,期末考也有一题类似的,不过不超过10进制。

用了白书上的方法,使用字符串常量来简化输出。
 1 #include<stdio.h>
 2 #include<math.h>
 3 const char output[18] = "0123456789ABCDEF";
 4 int main()
 5 {
 6     int num, base;
 7     int ans[64];
 8     int len, i;
 9     while ( scanf("%d %d", &num, &base) != EOF )
10     {
11         len = 0;
12         do
13         {
14             ans[len++] = num % base;
15             num = num/base;
16         }while( num !=  0 );
17         
18         for ( i = len - 1; i >= 0; i-- )
19         {
20             printf( "%c", output[ans[i]] );
21         }
22         printf("\n");
23         
24     }
25     return 0;
26 }

 

posted @ 2013-01-19 14:35  Joyee  阅读(215)  评论(0编辑  收藏  举报