HOJ:2031 进制转换

进制转换

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 18495    Accepted Submission(s): 10386


Problem Description
输入一个十进制数N,将它转换成R进制数输出。
 

 

Input
输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=16, R<>10)。
 

 

Output
为每个测试实例输出转换后的数,每个输出占一行。如果R大于10,则对应的数字规则参考16进制(比如,10用A表示,等等)。
 

 

Sample Input
7 2 23 12 -4 3
 

 

Sample Output
111 1B -11
 
 
解题思路: 
以第一个例子 7 2
7%2=1
7/2=3
3%2=1
3/2=1
1%2=1
1/2=0   //结束
结果是111
我的代码:
 1 #include <stdio.h>
 2 char A[100];
 3 int main()
 4 {
 5     int num,r,i,t,j,mark;
 6     while(~scanf("%d%d",&num,&r)){
 7         i=0;
 8         mark=0;
 9         if(num<0){
10             mark=1;
11             num=-num;
12         }
13         while(num>0){
14             t=num%r;
15             if(t>9)    A[i]= t-10+'A';
16             else    A[i]= t+'0';    
17             ++i;
18             num/=r;
19         }
20         if(mark==1) printf("-");
21 
22         for(j=i-1;j>=0;j--){
23             printf("%c", A[j]);
24         }
25         printf("\n");
26     }
27     return 0;
28 }

 

 

大神级别代码:

 1 #include <stdio.h>
 2 #include <string.h>
 3 
 4 void ttor(int n, int r)
 5 {
 6     if (n)
 7     {
 8         ttor(n / r, r);
 9         printf("%c", n % r > 9 ? n % r - 10 + 'A' : n % r + '0');
10     }
11 }
12 
13 int main(void)
14 {
15     int n;
16     int r;
17 
18     while (scanf("%d%d", &n, &r) != EOF)
19     {
20         if (n > 0)
21             ttor(n, r);
22         else if (!n)//表示n==0
23             putchar('0');
24         else
25         {
26             putchar('-');
27             ttor(-n, r);
28         }
29         putchar('\n');
30     }
31 
32     return 0;
33 }

 

 
posted @ 2013-07-18 01:19  Levi.duan  阅读(323)  评论(0编辑  收藏  举报