牛客网 124C--有趣的二进制

链接:https://www.nowcoder.com/acm/contest/124/C

来源:牛客网

题目描述

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

输入描述:

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

输出描述:

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

示例1

输入

 
  

15

输出

 
  

4


思路:
本来是想自己把负数转换成其补码,但是一直WAWAWAWA。。。后来听大佬说加个unsigned 就A了,果然...
后来就琢磨这个东西的原理,然而竟然真的是存的就是其补码。。然后就很简单了,。。。
代码:

#include<bits/stdc++.h>
using namespace std;
#define inf 0x3f3f3f3f
#define mod 1000000007
unsigned long long num,n,ans,x,er[66];
int main()
{
    er[0]=1;
    for(int i=1;i<=64;i++)
    {
        er[i]=er[i-1]*2;
    }
    while(~scanf("%lld",&n))
    {
        ans=0;
        while(n)
        {
            if(n%2==1) ans++;
            n/=2;
        }
        cout<<ans<<endl;
    }
}

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值