#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main(){
int left, right, m, n, k, sum;
while(scanf("%d %d", &m, &n) != EOF && m != 0 && n != 0){
left = right = m;
k = 1;
while(2 * right + 1 <= n){
right = 2 * right + 1;
left *= 2;
++k;
}
sum = pow(2, k) - 1;
if(2 * left <= n) sum += n - 2 * left + 1;
printf("%d\n", sum);
};
return 0;
}
0.0分
2 人评分
不容易系列2 (C语言代码)浏览:650 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:693 |
Tom数 (C语言代码)浏览:736 |
C二级辅导-同因查找 (C语言代码)浏览:663 |
震宇大神的杀毒软件 (C语言代码)浏览:1241 |
简单的a+b (C语言代码)浏览:542 |
printf基础练习2 (C语言代码)浏览:567 |
计算质因子 (C++代码)浏览:1641 |
三角形 (C语言代码)浏览:914 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:785 |