进制转换

Problem A

Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other)
Total Submission(s) : 1   Accepted Submission(s) : 1
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
 


代码:

挺容易的一道题:

 1 #include<iostream>

 2 #include<cstdio>

 3 #include<cstring>

 4 using namespace std;

 5 char s1[]="0123456789ABCDEF";

 6 int main()

 7 {

 8     int n,r,pos;

 9     int str[30];

10     bool flag ;

11     while(scanf("%d%d",&n,&r)!=EOF)

12     {

13         memset(str,0,sizeof str);

14         pos=-1;

15         flag=false;

16         if(n<0)

17             n=-n,flag=true;

18         while(n)

19         {

20          if(n%r)

21            str[++pos]=n%r;

22          else

23            str[++pos]=0;

24            n/=r;

25         }

26          if(flag)

27                 printf("-");

28          for(;pos>=0;pos--)

29            printf("%c",s1[str[pos]]);

30            puts("");

31          

32     }

33     return 0;

34 }
View Code

 

你可能感兴趣的:(进制转换)