C语言十进制转二进制代码实例
用C语言实现将十进制转化为二进制,并统计转换后的二进制码中1的个数。
#include<stdio.h>
intbinaryNum[16];//存放转换后得到的二进制码
intcount=0;//计数十进制整数被2除的次数
intoneCount=0;//得到的二进制码中1的个数
voidmain(){
intnum;
printf("输入一个十进制的整数:");
scanf("%d",&num);
while((num/2)!=1){//判断条件为:除以2之后的商不等于1
binaryNum[count]=num%2;//取余后的数字存入数组
num/=2;//num=num/2;进行下一轮的判断
count++;//此变量用来指定数组下标
}
binaryNum[count+1]=1;//最后一次除法做完以后,剩下的商一定是1,所以在最后手动添加一个1
printf("二进制数值为:");
//倒序打印出数组中的元素
//sizeof(整形数组)/sizeof(整形单个元素大小)=数组的元素个数
for(inti=sizeof(binaryNum)/sizeof(int)-1;i>=0;i--){
if(binaryNum[i]==1)
oneCount++;//出现一次1就累加
printf("%d",binaryNum[i]);
}
printf("\n共有%d个1\n",oneCount);
}