#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);
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有