题目描述
给 定 一 个 长 度 为 n 的 数 列 , 请 你 求 出 数 列 中 每 个 数 的 二 进 制 表 示 中 1 的 个 数 。 给定一个长度为 n 的数列,请你求出数列中每个数的二进制表示中 1 的个数。 给定一个长度为n的数列,请你求出数列中每个数的二进制表示中1的个数。
输入格式
第
一
行
包
含
整
数
n
。
第一行包含整数 n。
第一行包含整数n。
第 二 行 包 含 n 个 整 数 , 表 示 整 个 数 列 。 第二行包含 n 个整数,表示整个数列。 第二行包含n个整数,表示整个数列。
输出格式
共
一
行
,
包
含
n
个
整
数
,
其
中
的
第
i
个
数
表
示
数
列
中
的
第
i
个
数
的
二
进
制
表
示
中
1
的
个
数
。
共一行,包含 n 个整数,其中的第 i 个数表示数列中的第 i 个数的二进制表示中 1 的个数。
共一行,包含n个整数,其中的第i个数表示数列中的第i个数的二进制表示中1的个数。
数据范围
1
≤
n
≤
100000
,
1≤n≤100000,
1≤n≤100000,
0
≤
数
列
中
元
素
的
值
≤
1
0
9
0≤数列中元素的值≤10^9
0≤数列中元素的值≤109
输入样例:
5
1 2 3 4 5
输出样例:
1 1 2 1 2
C++ 代码
#include <iostream>
using namespace std;
int lowbit(int x) {
return x & -x;
}
int main() {
int n;
cin >> n;
while(n --){
int x;
cin >> x;
int res =0;
//解法一:
//while(x) x -= lowbit(x), res++;
//解法二:
for(int i = 0; i < 32; i ++)
if(x >> i & 1) res++;
cout << res << " ";
}
return 0;
}