C/C++教程

c语言中输出非负整数用二进制表示时一共有多少个1或者0组成

本文主要是介绍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;
} 

 

这篇关于c语言中输出非负整数用二进制表示时一共有多少个1或者0组成的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!