A
来源:互联网 发布:java shiro 权限控制 编辑:程序博客网 时间:2024/06/05 18:25
A - 进制转换
Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64uDescription
输入一个十进制数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;}
阅读全文
0 0