首页 > 代码库 > CodeForces484A——Bits(贪心算法)

CodeForces484A——Bits(贪心算法)

Bits


Let‘s denote as the number of bits set (‘1‘ bits) in the binary representation of the non-negative integer x.
You are given multiple queries consisting of pairs of integers l and r. For each query, find the x, such that l ≤ x ≤ r, and is maximum possible. If there are multiple such numbers find the smallest of them.
Input
The first line contains integer n — the number of queries (1 ≤ n ≤ 10000).
Each of the following n lines contain two integers li, ri — the arguments for the corresponding query (0 ≤ li ≤ ri ≤ 1018).
Output
For each query print the answer in a separate line.
Sample test(s)
Input
3
1 2
2 4
1 10
Output
1
3
7
题目大意:

    给定L,R,输出X,X为[L,R]中化为二进制之后一的个数最多的那个数,(同时存在多个解,输出最小的那个)。

解题思路:

    设L,R的从高位开始有t1位相同,那么根据常识,x的前t1位(从高位开始数)必然也与LR相同。又因为L<=R,那么t1+1位不同,必然是L为0,R为1。

    此时将x的t1+1位赋值为0,后面所有为都为1。那么求出的X: L<=x<R 成立,且在[L,R)区间中为最优解。

    存在特殊情况:R换成二进制之后全部为1,所以要加一个判断。判断x在t1+1位为1的时候是否绝对大于R,绝对大于的话,就将t1+1赋值为0;反之,赋值为1。

Code:

 1 /************************************************************************* 2     > File Name: CF484A.cpp 3     > Author: Enumz 4     > Mail: 369372123@qq.com 5     > Created Time: 2014年11月06日 星期四 01时49分25秒 6  ************************************************************************/ 7  8 #include<iostream> 9 #include<cstdio>10 #include<cstdlib>11 #include<string>12 #include<cstring>13 #include<list>14 #include<queue>15 #include<stack>16 #include<map>17 #include<set>18 #include<algorithm>19 #include<cmath>20 #include<bitset>21 #include<climits>22 #define MAXN 10000023 #define LL long long24 using namespace std;25 int main()26 {27     LL a,b,ans;28     int T,k;29     cin>>T;30     while (T--)31     {32         ans=0;33         cin>>a>>b;34         int i;35         bool flag=0;36         for (i=60; i>=0; i--)37         {38             if (flag)39             {40                 ans+=1LL<<i;41                 continue;42             }43             if((a&(1LL<<i))==(b&(1LL<<i)))44             {45                 if ((a&(1LL<<i))!=0)46                     ans+=1LL<<i;47             }48             else49             {50                 flag=1;51                 k=i;52                 i++;53             }54         }55         if (ans>b)56             ans=ans^(1LL<<k);57         cout<<ans<<endl;58     }59     return 0;60 }

 

CodeForces484A——Bits(贪心算法)