输入一个十进制数N,将它转换成R进制数输出(运用递归实现)

来源:互联网 发布:平台优化方案 编辑:程序博客网 时间:2024/06/05 01:14
#include<stdio.h>
int cnt=0;                             //用来记录每一个进制存放的位置
char num[20];   //用来存放每一个进制的数   


void fun(int a,int b)
{
if(a==0)   //递归的终止条件
return;
fun(a/b,b);                       //顺序递归
num[cnt++] = a%b;                  //逆序递归



int main()
{
int a,b;
while(scanf("%d%d",&a,&b)!=EOF)
{
if(a<0)
{
a = -a;
fun(a,b);
printf("-");
for(int i=0;i<cnt;i++)
{
if(num[i]<10)
printf("%d",num[i]);
else
printf("%c",num[i]+'A'-10);
}
}
else
{
fun(a,b);
for(int i=0;i<cnt;i++)
{
if(num[i]<10)
printf("%d",num[i]);
else
printf("%c",num[i]+'A'-10);
}
}
printf("\n");
cnt = 0;


}
}

3 0
原创粉丝点击