题解 | #求int型正整数在内存中存储时1的个数#

求int型正整数在内存中存储时1的个数

https://www.nowcoder.com/practice/440f16e490a0404786865e99c6ad91c9

#include <bits/stdc++.h>
using namespace std;
int main()
{
    int one = 0;
    int time = 0;
    int num;
    cin>>num;
    while(pow(2,time)<num)
    {
        time++;
    }
    while(num)
    {
        if(num==pow(2,time))
        {
            num=num-pow(2,time);
            one++;            
        }
        else if(num>pow(2,--time))
        {
            num=num-pow(2,time);
            one++;
        }
    }
    cout<<one;
}

全部评论

相关推荐

牛客717484937号:双飞硕没实习挺要命的
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务