#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取整法)
参考资料:
百度百科-二进制
思路:十进制整数转换为二进制整数采用"除2取余,逆序排列"法。具体做法是:用2整除十进制整数,可以得到一个商和余数;再用2去除商,又会得到一个商和余数,如此进行,直到商为0时为止,然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。
参考代码:
#include<stdio.h>int main()
{
int a,s[20],i=0,rem
printf("请输入整数:\n")
scanf("%d",&a)
while(a){
rem=a%2
a=a/2
s[i++]=rem
}
printf("输出的二进制:")
while(i>0)
printf("%d",s[--i])
printf("\n")
return 0
}
/*
输出:
请输入整数:
10
输出的二进制:1010
*/