UPC-喜爱(打表+二分)

简介: UPC-喜爱(打表+二分)

喜爱

时间限制: 1 Sec 内存限制: 128 MB

[提交] [状态]

题目描述

小s最近对数字情有独钟。他又发现了一种神奇的数字。对于数x,如果它二进制表示中只有一位是0,则x就会被小s所喜爱。比如5,二进制为101,则它被小s所喜爱。


现在,小s想知道,对于一个区间[L,R],有多少数是他所喜爱的。

输入

输入包含多组数据。

输入第一行T,表示数据组数。

每组数组仅有一行,包含两个正整数[L,R]。

输出

对于每组数据输出一行,表示答案。

样例输入 Copy

2

5 10

2015 2015

样例输出 Copy

2

1

提示

对于30%的数据:L,R≤106,T≤10

对于60%的数据:L,R≤1010,T≤100

对于100%的数据:L,R≤1018,T≤10000


规律题(太搞心态了)

写出前几项就找出规律来了,其实还是进制的运用

好像这题挺水?(手动划掉)

#include<bits/stdc++.h>
typedef unsigned long long ll;
using  namespace std;
const int maxn=1e6+7,mod=1e9+7,inf=0x3f3f3f3f;
///0:0
2
///10:2
4
///110:6
///1
///101:5
8
///1110:14
///1
///1101:13
///2
///1011:11
16
///11110:30
///1
///11101:29
///2
///11011:27
///4
///10111:23
ll a[maxn],cnt;
map<ll,bool>mp;
void init(){
    ll k=2,tot=1;
    a[cnt++]=0;
    for(ll i=2;i<1e19;i+=k){
        ll m=1,last=i;
        a[cnt++]=i;
        mp[i]=1;
        for(ll j=1;j<tot;j++){
            a[cnt++]=last-m;
            mp[last-m]=1;
            m=m*2;
            last=a[cnt-1];
            //cout<<"%"<<i<<" "<<j<<" "<<m<<endl;
        }
       // cout<<"&"<<i<<" "<<k<<" "<<tot<<endl;
        k*=2;tot++;
       // cout<<i<<" "<<k<<" "<<tot<<endl;
    }
}
void AC(){
    init();
    sort(a,a+cnt);
    ///for(int i=0;i<cnt;i++) cout<<a[i]<<" ";
    int t;scanf("%d",&t);
    ll l,r;
    while(t--){
        cin>>l>>r;
        if(l==r){
            if(mp.count(l)) puts("1");
            else puts("0");
            continue;
        }
        if(l>r) swap(l,r);
        ///对于左边界:找第一个大于等于左边界的数
        ///对于右边界:找第一个大于右边界的数再减一
        ll posl=lower_bound(a,a+cnt,l)-a;
        ll posr=upper_bound(a,a+cnt,r)-a-1;
        //cout<<posl<<" "<<posr<<endl;
        printf("%llu\n",posr-posl+1);
    }
}
int main(){
    AC();
    return 0;
}

学长的数位DP:博客友链

640.jpg

还有种纯模拟的和高级打表方法的,明天等大佬更完后附上友链~

就先这样~

目录
相关文章
|
算法 测试技术 C++
C++算法:美丽塔O(n)解法单调栈
C++算法:美丽塔O(n)解法单调栈
|
6月前
代码随想录Day29 贪心04 LeetCode T860 柠檬水找零 T406 根据身高重建队列 T452 用最少得箭引爆气球
代码随想录Day29 贪心04 LeetCode T860 柠檬水找零 T406 根据身高重建队列 T452 用最少得箭引爆气球
41 0
|
算法 JavaScript 前端开发
日拱算法:解两道“杨辉三角”题
什么是“杨辉三角”,想必大家并不陌生~~ 在「杨辉三角」中,每个数是它左上方和右上方的数的和。
UPC-篮球运动(线性DP)
UPC-篮球运动(线性DP)
88 0
UPC-篮球运动(线性DP)
|
定位技术
宝岛探险(求岛屿大小,染色法) 宽搜 深搜
宝岛探险(求岛屿大小,染色法) 宽搜 深搜
宝岛探险(求岛屿大小,染色法) 宽搜 深搜
UPC-探险(线段树+二分)
UPC-探险(线段树+二分)
81 0
|
机器人
UPC—— 最勇敢的机器人(并查集+分组背包)
UPC—— 最勇敢的机器人(并查集+分组背包)
78 0
UPC-游戏智商+ 路标 (动态规划+DFS)
UPC-游戏智商+ 路标 (动态规划+DFS)
115 0
|
人工智能 BI
UPC窃贼与火柴——贪心
题目描述 一个窃贼进入了火柴仓库,想要偷尽可能多的火柴。仓库里有m个集装箱,第i个集装箱里有ai个火柴盒,每个火柴盒里有bi根火柴。所有火柴盒大小相同。窃贼的帆布背包恰能容纳n个火柴盒。你的任务是找出窃贼能拿走的火柴的最大数量。他没时间重新调整火柴盒中的火柴,这就是他只是挑选不超过n个其包含火柴数之和最大的火柴盒的原因
114 0
UPC朋友——并查集
题目描述 有一个城镇,住着n个市民。已知一些人互相为朋友。引用一个名人的话说,朋友的朋友也是朋友。意思是说如果A和B是朋友,C和B是朋友,则A和C是朋友.你的任务是数出最大朋友组的人数。
115 0