C 有趣的二进制

链接: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即可

#include<cstdio>
#include<cstring>
#include<cmath>
#include<string>
#include<queue>
#include<stack>
#include<map>
#include<vector>
#include<algorithm>
#include<iostream>
#define LL long long
#define PI acos(-1.0)
#define INF 0x3f3f3f3f
using namespace std;
int main()
{
	LL n;
	while(~scanf("%lld",&n))
	{
		LL ams=0;
		while(n)
		{
			if(n&1)
				ams++;
			n>>=1;
		}
		printf("%lld\n",ams);
	}
	return 0;
}






猜你喜欢

转载自blog.csdn.net/gtuif/article/details/80787146