c语言实现2-20任一进制的转换,任意进制间的转换(用c语言实现)

今天自己写了一个进制转换的代码,不甚满意,看看了别人的代码。拿过来借鉴一下

http://lilongfei1030.blog.163.com/blog/static/860152820079793133315/

一下文字都是这位老兄的成果,我只是简单的搬运工。

/*

问题:任意进制间的转换(用c语言实现)

编程将任意d1进制的正整数转换成d2进制表示形式。 其中(2≤d1≤16,2≤d2≤16) 当进制大于10时,在每一位上的A、B、C、D、E、F分别代表数值10、11、12、13、14、15。

输入:用空格分开的三个数,分别表示进制d1下要转换的数num、进制d1、进制d2;

输出:数X的d2进制表示形式。

输入示例:

101111   2  16

1030    2  10

aaaa  16  2

hhjssk  10  8

输出示例:

2F

error

100101010100000

error

*/

#include

#define M sizeof(unsigned int)*8

unsigned long n;

int trans1(char a[],int d1) /*将d1进制的num,转换为十进制数s*/

{

int i=0,num,s=0,P=1;

while(P)

{

if(a[i]>='A'&&a[i]<='F') num=a[i]-'0'-7;

else if (a[i]>='a'&&a[i]<='f') num=a[i]-'0'-39;

else if (a[i]>='0'&&a[i]<='9') num=a[i]-'0';

else{

printf("Error!\n");

break;

}

if(num

{

if(i==0) s=num;

else

{

s*=d1;

s+=num*d1;

}

}

else

{

printf("Error!\n"); /*不合规则(d1进制)的num*/

break;

}

if( a[++i]=='\0') P=0;

}

return s;

}

int trans2(unsigned long n, int d, char s[]) /* 将无符号整数n翻译成d(2

{

static char digits[] ="0123456789ABCDEF"; /* 十六进制数字的字符 */

char buf[M+1];

int j, i = M;

s[0]='\0';

if(d<2||d>16)

{

s[0]='\0'; /* 不合理的进制,置s为空字符串 */

return 0; /* 不合理的进制,函数返回0 */

}

buf[i]='\0';

do

{

buf[--i]=digits[n%d]; /*译出最低位,对应字符存入对应工作数组中*/

n/=d;

}while(n);

for(j=0;(s[j]=buf[i])!='\0';j++,i++); /*将译出在工作数组中的字符串复制到s */

return j;

}

main()

{

char str[33];

int d1,d2;

while(scanf("%s %d %d",&str,&d1,&d2)!=EOF)

{

n=trans1(str,d1);

if(n&&trans2(n,d2,str)) printf("%s\n",str);

str[0]='\0';

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值