有趣的二进制

有趣的二进制

时间限制:C/C++ 1秒 空间限制:C/C++ 131072K

链接:https://www.nowcoder.com/acm/contest/124/C
来源:牛客网

题目描述

小新在学C语言的时候,邝老师告诉他double类型的数据在表示小数的时候,小数点后的有效位是有限的,但是没有告诉他这是为什么,后来他发现0.1的二进制是一个无限循环小数0.000110011001100110011001100···,如果只取27位小数,再转换成十进制的话就变成了0.09999999403953552,小新开心的解决了这个问题。与此同时,小新又有了一个新的问题:一个数在64位二进制补码表示下,一共有多少个1。因为小数有无解的情况,所以我们保证输入的都是整数。

输入描述:

有多组数据,每一行为一个数字n。

输出描述:

输出这个数字在二进制补码下1的个数。
示例1

输入

15

输出

4

解题思路

这道题很水,就是让你求转化成二进制有多少个1,这道题有个技巧可以把n定义成unsigned long long类型的(无符号型的),否则会时间超限。具体见代码:
#include 
int main()
{
    unsigned long long n, ans;
    while (~scanf("%lld", &n))
    {
        ans = 0;
        while (n)
        {
            if(n & 1)
                ans++;
            n >>= 1;
        }
        printf("%lld\n", ans);
    }
    return 0;
}

你可能感兴趣的:(#,水题,ACM之路)