题解 | #求int型正整数在内存中存储时1的个数#
求int型正整数在内存中存储时1的个数
https://www.nowcoder.com/practice/440f16e490a0404786865e99c6ad91c9
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
int main() {
//第一遍想着一直除2,没除一次加一,但是如果是128这种,其实就一个1,不行,一直除二是进制转换
vector<int>vec;
int num;
int count = 0;
cin>>num;
while(num>0){
vec.push_back(num%2);
num /= 2;
}
//反向输出就是二进制数
for(vector<int>::size_type i = 0;i<vec.size();i++){
if(vec[i]==1){//找1
count++;
}
}
cout<<count;
return 0;
}
// 64 位输出请用 printf("%lld")
