PS:要注意當N==0時,例外考慮,我已開始就沒考慮這!
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
[plain]
#include <stdio.h>
int main()
{
int i;
int j;
int n;
int m;
int l;
int flag;
char num[1001];
while(scanf("%d %d", &n, &m)!=EOF && (m>=2 && m<=16))
{
j=0;
flag=1;
if(n<0)
{
flag=0;
n=-n;
}
if(n==0)
{
num[j++]=n+'0';
}
if(m>=2 && m<10)
{
while(n)
{
l=n%m;
num[j++]=l+'0';
n=n/m;
}
}
else if(m>=10 && m<=16)
{
while(n)
{
l=n%m;
if(l>=10 && l<=15)
{
num[j++]='A'+l-10;
}
else
{
num[j++]=l+'0';
}
n=n/m;
}
}
if(flag==0)
{
printf("-");
}
for(i=j-1; i>=0; i--)
{
printf("%c", num[i]);
}
printf("\n");
}
}
#include <stdio.h>
int main()
{
int i;
int j;
int n;
int m;
int l;
int flag;
char num[1001];
while(scanf("%d %d", &n, &m)!=EOF && (m>=2 && m<=16))
{
j=0;
flag=1;
if(n<0)
{
flag=0;
n=-n;
}
if(n==0)
{
num[j++]=n+'0';
}
if(m>=2 && m<10)
{
while(n)
{
l=n%m;
num[j++]=l+'0';
n=n/m;
}
}
else if(m>=10 && m<=16)
{
while(n)
{
l=n%m;
if(l>=10 && l<=15)
{
num[j++]='A'+l-10;
}
else
{
num[j++]=l+'0';
}
n=n/m;
}
}
if(flag==0)
{
printf("-");
}
for(i=j-1; i>=0; i--)
{
printf("%c", num[i]);
}
printf("\n");
}
}