求一整数的二进制表示中1的个数

题目: 输入一个int型的正整数,计算出该int型数据在内存中存储时1的个数。

思路1:一个int占32位,将其右移32次,每次与1相与,结果为1,则计数值加1;

/*************************************************************************
    > File Name: e17.c
    > Author: LNM
    > Mail: liunenming@gmail.com 
    > Created Time: 2018年09月07日 星期五 19时31分22秒
    >function:输入一个int型的正整数,计算出该int型数据在内存中存储时1的个数。
 ************************************************************************/

#include<stdio.h>

int main()
{
    int num,i,count;
    scanf("%d",&num);
    
    for(i = 0;i < 32;i ++)
    {
        if((num & (1 << i)))
            count ++;
    }

    printf("%d",count);
}

思路2: 一整数表示为二进制数x,x-1得到的结果是x的最后一个1及其之后的位取反(1100 - 1 = 1011),那么x & (x -1)表示x中少了一个1 (1100 & 1011 = 1000,还剩下1个1),所以有几个1就循环几次

#include<stdio.h>

int main()
{
    int num,count;
    scanf("%d",num);
    while(num)
    {
        num = num & (num - 1);
        count ++;
    }
    printf("%d",count);
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值