当前位置:首页 > 未命名 > 正文

用C语言实现将十进制转化为二进制,并统计转换后的二进制码中1的个数。

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 #include <stdio.h> int binaryNum[16]; //存放转换后得到的二进制码 int count=0; //计数十进制整数被2除的次数 int oneCount=0; //得到的二进制码中1的个数 void main(){ int num; 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( int i=sizeof(binaryNum)/sizeof(int)-1; i>=0; i-- ){ if( binaryNum[i] == 1) oneCount++; //出现一次1就累加 printf("%d",binaryNum[i]); } printf("\n共有%d个1\n",oneCount); }

如果您对该产品感兴趣,请填写办理(客服微信:xiaoxiongyidong)

为您推荐:

发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。