#include <stdio.h>
void main()
{
//进制转换函数的声明
int transfer(int x)
int x
printf("请输入一个十进制数:")
scanf("%d",&x)
printf("转换成二进制数是:%d\n",transfer(x))
}
int transfer(int x)
{
int p=1,y=0,yushu
while(1)
{
yushu=x%2
x/=2
y+=yushu*p
p*=10
if(x<2)
{
y+=x*p
break
}
}
return y
}
扩展资料:
(1)二进制转十进制
方法:“按权展开求和”
【例】:
规律:个位上的数字的次数是0,十位上的数字的次数是1,......,依次递增,而十分位的数字的次数是-1,百分位上数字的次数是-2,......,依次递减。
注意:不是任何一个十进制小数都能转换成有限位的二进制数。
(2)十进制转二进制
十进制整数转二进制数:“除以2取余,逆序排列”(除二取余法)
【例】:
89÷2 ……1
44÷2 ……0
22÷2 ……0
11÷2 ……1
5÷2 ……1
2÷2 ……0
1
十进制小数转二进制数:“乘以2取整,顺序排列”(乘2取整法)
参考资料:
百度百科-二进制
#include <stdio.h>
void d2n(unsigned long d,int n)
{
if(d>=n)
{
d2n(d/n,n)
}
printf("%c","0123456789ABCDEF"[d%n])
}
int main()
{
unsigned long d
int n
scanf("%lu",&d)
d2n(d,2)
return 0
}