设为首页 加入收藏

TOP

问题一百四十一:进制转换
2014-11-23 22:13:06 来源: 作者: 【 】 浏览:1
Tags:问题 一百四十一 进制 转换

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

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

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");
}
}

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇问题一百三十九:函数cos()和sin(.. 下一篇问题一百四十:鞍点

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: