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< 

相关内容

热门资讯

“湘超”夺冠赠车事件后续,永州... 近日,“湘超”夺冠赠车事件引发关注,此前承诺“永州队夺冠就给每位队员奖励一台车”的永州新兰天集团董事...
国家大基金,大动作! 2026年1月2日,香港交易所信息显示,2025年12月29日,中芯国际同意向国家集成电路产业投资基...
李在明:韩国始终尊重一个中国 本文转自【@央视新闻】; 李在明:韩中两国建交时,韩国政...
分析师:特斯拉Q4销量降幅好于...   特斯拉第四季度销量同比下滑16%。尽管这一销量数据略低于市场普遍预期的交付量,但韦德布什证券公司...
内蒙古:近三千件艺术精品全景式... 02:40记者1月2日从内蒙古巴彦淖尔市文旅广电局获悉,近期,近三千件艺术精品集中亮相首届巴彦淖尔艺...