A

来源:互联网 发布:java shiro 权限控制 编辑:程序博客网 时间:2024/06/05 18:25
A - 进制转换
Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u
Submit Status Practice HDU 2031

Description

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

Input

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

Output

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

Sample Input

7 223 12-4 3
 

Sample Output

111
1B
-11 
先计算一个数的大小,然后在用数组存储的16个字符相对应的输出。。

#include<stdio.h>char b[16]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};int main(){          long long  n,r;while(scanf("%lld%lld",&n,&r)!=EOF){long long a[100010];long long k=0;if(n==0){printf("0\n");}     else     if(n!=0)     { if(n<0){n=-n;printf("-");} while(n!=0) { a[k++]=n%r; n=n/r;  }    for(int i=k-1;i>-1;i--)  {       int shi=a[i];       printf("%c",b[shi]);  }  printf("\n"); }  }return 0;}



原创粉丝点击