题目:输入一个十进数,将其转换成 N 进制数(0<N<=16)。
下面的代码是我写的,新手上路,写得比较繁琐,麻烦大家看一下啦~
在转换为小于十的数制(比如九进制)的时候没有问题,
但在转化为大于十的数制(比如十二进制)的时候就出现问题啦
大家帮忙运行一下看一下
帮我看一下什么问题啊~
多谢指点~
(部分变量名说明:tennum:输入的十进制数
n:要转换的数制
bgnnum[]:当转换数制大于十时存储结果的数组
bittime:位权的次数,如3进制百位位权为32,该变量就为2
bitnum:位权的数值,如3进制百位位权为9(32=9)
num[]:存贮结果数字各个数位上的数字)
# include <stdio.h>
void main ()
{
int tennum,n,i,j;
char bgnnum[100];
long int tonnum(int tennum,int n,char bgnnum[]);
for(i=0;i<=100;i=i+1)bgnnum[i]='\0'; /*输入十进制数,并确定转换为的数制*/
printf("Enter a number:");
scanf("%d",&tennum);
printf("Decide the number sys:");
scanf("%d",&n);
if(n<10)printf("%d",tonnum(tennum,n,bgnnum));/*分小于十与大于十的两种数制类型处理,函数tonnum()的具体 解释见后面函数定义部分的注释*/
else if(n>10)
{
for(i=0;bgnnum[i]!='\0';i=i+1)
for(j=i;j>=0;j=j-1)printf("%c",bgnnum[j]);
}
getchar();
getchar();
}
long int tonnum(int tennum,int n,char bgnnum[]) /*数制转换函数,当转化的数制小于十的时候把转化结果由函
数本身带回,当数制大于十的时候结果按倒序放在字符数组
不bgnnum[]里面,例如结果12A,bgnnum[0]='1',bgnnum[1]
='2'.bgnnum[2]='A'*/
{
int i,bittime=0,bitnum=1,leftnum,num[10],j;
long int result=0;
for(i=0;i<=9;i=i+1)num[i]=-1;
for(i=1;bitnum<=tennum;i=i+1)
{
bitnum=bitnum*n;
bittime=i;
}
leftnum=tennum;
bitnum=bitnum/n;
bittime=bittime-1;
for(;bittime>=0;)
{
for(i=1;leftnum>=bitnum*i;i=i+1);
num[bittime]=i-1;
leftnum=leftnum-num[bittime]*bitnum;
bitnum=bitnum/n;
bittime=bittime-1;
}
if(n<10)
{
for(i=0;num[i]!=-1;i=i+1)
{
bitnum=1;
for(j=0;j<=i-1;j=j+1)bitnum=bitnum*10;
result=num[i]*bitnum+result;
}
return(result);
}
else if(n>10)
{
for(i=0;num[i]=-1;i=i+1)
if(num[i]<=9)bgnnum[i]=num[i]+48;
else if(num[i]>9)bgnnum[i]=64+num[i]-9;
return(-1);
}
}
[此贴子已经被作者于2007-6-21 13:48:48编辑过]