c语言中输出非负整数用二进制表示时一共有多少个1或者0组成
作者:互联网
001、
#include <stdio.h> // 文件包含指令, 头文件 int main(void) { unsigned i; // 声明一个unsigned int 型的变量。 printf("i = "); scanf("%u", &i); // 此处从键盘输入,使用%u运算符 int j = 0; // 声明1个int型变量, 并初始化为0int length_unsigned_int = sizeof(unsigned int); ## 此处利用sizeof函数返回unsigned int型变量的长度(字节数) while(i) // 循环条件为i不为0 { if(i & 1u) // 判断i用二进制表示时,末尾的数字是否为1, 如果是,判定结果为1, 同时j递增 { j++; } i >>= 1; // 同时i的二进制数向右移动一位 } // 当i中全部为0时, i为0, 循环结束 printf("j(1) = %d\n", j); // 输出1的计数 printf("k(0) = %d\n", length_unsigned_int * 8 - j); // unsigned int型的总字节数 * 8(总位数), 然后减去1的个数,等位剩余的0的位数 return 0; }
标签:字节数,非负,二进制,unsigned,整数,int,printf,sizeof 来源: https://www.cnblogs.com/liujiaxin2018/p/16590256.html