输入一个十进制数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
#include<stdio.h>
#include<string.h>
int main()
{
int m,n,i;
int a[100];
while(~scanf("%d%d",&n,&m))
{
if(n<0) //判断n,如果为负数,先输出负号
{
printf("-");
n=-n;
}
if(n==0)
{
printf(“0\n”);
continue;
}
int x=0;
while(n)
{
a[x]=n%m; //将余数存储到数组中
x++;
n=n/m;
}
for(i=x-1;i>=0;i–) //倒输出
{
if(a[i]>=10)
printf("%c",‘A’+a[i]-10); //数组中的数转化为字母
else
printf("%d",a[i]);
}
printf("\n");
}
return 0;
}