题目求的是1的个数,二进制中,只包含0和1,所以只需要把每个数跟2的余数相加求和即可
#include using namespace std; //求二进制 int binary(int num) { int sum = 0; while(num != 0) { sum += num % 2; num /= 2; } return sum; } int main() { int L,R,sum = 0; cin >> L >> R; for (int i = L; i <= R; ++i) { sum += binary(i); } cout << (L == R ? binary(L) : sum) << endl; return 0; }
0.0分
1 人评分
剪刀石头布 (C语言代码)不知道怎么直接在scanf中用枚举变量浏览:1318 |
WU-蓝桥杯算法提高VIP-企业奖金发放 (C++代码)浏览:1176 |
printf基础练习2 (C语言代码)浏览:646 |
C语言程序设计教程(第三版)课后习题11.3 (C语言代码)浏览:577 |
Tom数 (C语言代码)浏览:555 |
C语言训练-自守数问题 (C语言代码)浏览:749 |
数列问题 (C语言代码)浏览:1022 |
整除的尾数 (C语言代码)浏览:814 |
盐水的故事 (C语言代码)浏览:1529 |
C语言程序设计教程(第三版)课后习题8.7 (C语言代码)浏览:807 |