CodeForces484A——Bits(贪心算法)
创始人
2024-04-11 13:56:44


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换成二进制之后全部为1,所以要加一个判断。判断x在t1+1位为1的时候是否绝对大于R,绝对大于的话,就将t1+1赋值为0;反之,赋值为1。

Code:

 6  ************************************************************************/7 8 #include9 #include
10 #include
11 #include
12 #include
13 #include
14 #include
15 #include
16 #include
17 #include
18 #include
19 #include
20 #include
21 #include
22 #define MAXN 100000
23 #define LL long long
24 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<b)
56             ans=ans^(1LL< 

相关内容

热门资讯

3月11日银河上证国有企业红利... 数据显示,3月11日,银河上证国有企业红利ETF(530880)遭净赎回53.53万元,位居当日股票...
大唐发电2026年3月12日涨... 2026年3月12日,大唐发电(sh601991)触及涨停,涨停价4.58元,涨幅10.1%,总市值...
中航西飞跌2.06%,成交额2... 3月12日,中航西飞盘中下跌2.06%,截至09:38,报27.62元/股,成交2.06亿元,换手率...
三美股份跌2.08%,成交额6... 3月12日,三美股份盘中下跌2.08%,截至09:38,报70.22元/股,成交6277.59万元,...
航发动力跌2.09%,成交额3... 3月12日,航发动力盘中下跌2.09%,截至09:38,报57.11元/股,成交3.47亿元,换手率...