Description
给定一个区间[x,y],求这个区间中满足下列条件的整数的个数:这个数恰好等于k个互不相等的2的整数次幂之和。例如x=15,y=20,k=2.则有且仅有下列三个数满足题意:
17=2^4+2^0;
18=2^4+2^1;
20=2^4+2^2;
(a^b代表是a的b次方)
Input
接下来输入T行,每行对应一个样例,每行有3个整数x, y, k(含义如上)。
第一行包含一个整数T,表示下面有T组数据。
数据规模:1<=x<=y<2^31-1 , 1<=k<=20 ;
Output
输出:每个样例对应一行,表示满足条件的数的个数。
Sample Input
215 20 21 100 4
Sample Output
326
也就是满足这个数的二进制里恰好有k个1。
比如13,1101,假设要求含3个1的个数,就等于紫色区域3个1的个数加上绿色区域2个1的个数加上紫色区域1个1的个数,如果这条路径本身满足则还要加1。
也就是满足这个数的二进制里恰好有k个1。
比如13,1101,假设要求含3个1的个数,就等于紫色区域3个1的个数加上绿色区域2个1的个数加上紫色区域1个1的个数,如果这条路径本身满足则还要加1。