Salazar Slytherin's Locket CodeForces - 855E

http://www.cnblogs.com/ftae/p/7590187.html

数位dp:

http://www.cnblogs.com/xz816111/p/4809913.html

http://blog.csdn.net/wust_zzwh/article/details/52100392

1.

 #include<cstdio>
#include<cstring>
typedef long long LL;
LL q,b,l,r;
LL ans[][][][];
LL w[];//记录拆出来的i进制的各个数字
//ans[i][j][state][k]:i进制,i进制下j长度,状态为state,k表示是否处于前导0
//状态为0-b-1的数字出现奇数/偶数次
LL dp(LL jz,LL pos,LL state,bool pre0,bool limit)//pre0表示当前位的前一位是不是0
{
if(pos<) return !state;//只有状态全0也就是所有数字出现偶数次才有1个答案,曾经忘记
if(!limit&&ans[jz][pos][state][pre0]!=-)
return ans[jz][pos][state][pre0];
LL i,res=,end=limit?w[pos]:(jz-);//当前位上界,limit为0表示前面某一位已经取了不是最高值,那么后面的位可以取0-9//曾经把最大值错写成9
for(i=;i<=end;i++)
if(i==&&pre0)//如果当前位取0,且前面都是前导0,那么开头的0显然是不计入状态的
res+=dp(jz,pos-,state,,limit&&i==w[pos]);//曾经忘记写limit&&
else
res+=dp(jz,pos-,state^(<<i),,limit&&i==w[pos]);
return limit?res:(ans[jz][pos][state][pre0]=res);
}
LL get(LL b,LL x)
{
LL g;
for(g=;x>;x/=b) w[++g]=x%b;
return dp(b,g,,,);//这一种的返回的直接就是1-x的总答案
}
int main()
{
memset(ans,-,sizeof(ans));
scanf("%I64d",&q);
while(q--)
{
scanf("%I64d%I64d%I64d",&b,&l,&r);
printf("%I64d\n",get(b,r)-get(b,l-));
}
return ;
}

2.

 #include<cstdio>
#include<cstring>
typedef long long LL;
LL q,b,l,r;
LL ans[][][];
LL w[];
//ans[i][j][state][k]:i进制,i进制下j长度,状态为state,k表示是否处于前导0
//状态为0-b-1的数字出现奇数/偶数次
LL dp(LL jz,LL pos,LL state,bool pre0,bool limit)//pre0表示当前位的前一位是不是0
{
if(pos<) return !state;//只有状态全0也就是所有数字出现偶数次才有1个答案
if(!limit&&!pre0&&ans[jz][pos][state]!=-)
return ans[jz][pos][state];
LL i,res=,start=pre0?:,end=limit?w[pos]:(jz-);//当前位上界,limit为0表示前面某一位已经取了不是最高值,那么后面的位可以取0-9
for(i=start;i<=end;i++)
res+=dp(jz,pos-,state^(<<i),,limit&&i==w[pos]);
if(!limit&&!pre0)
ans[jz][pos][state]=res;
return res;
}
LL get(LL b,LL x)
{
LL g,i,ret=;
for(g=;x>;x/=b) w[++g]=x%b;
for(i=g;i>=;i--) ret+=dp(b,i,,,i==g);//如果总位数不到g,那么显然所有数字都可以随便取
return ret;//这一种的dp返回的是0(1)-x的数中i位的数满足条件的答案
}
int main()
{
memset(ans,-,sizeof(ans));
scanf("%I64d",&q);
while(q--)
{
scanf("%I64d%I64d%I64d",&b,&l,&r);
printf("%I64d\n",get(b,r)-get(b,l-));
}
return ;
}

3.

Salazar Slytherin's Locket CodeForces - 855E的更多相关文章

  1. Codeforces 855E - Salazar Slytherin's Locket

    855E - Salazar Slytherin's Locket 题意 给出一个区间,问这个区间内有多少个数满足,将这个数转化为某个进制后,所有数的数量都为偶数. 分析 谁能想到 数位DP 的裸题竟 ...

  2. Codeforces - 65D - Harry Potter and the Sorting Hat - 简单搜索

    https://codeforces.com/problemset/problem/65/D 哈利波特!一种新思路的状压记忆化dfs,记得每次dfs用完要减回去.而且一定是要在dfs外部进行加减!防止 ...

  3. python爬虫学习(5) —— 扒一下codeforces题面

    上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...

  4. 【Codeforces 738D】Sea Battle(贪心)

    http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...

  5. 【Codeforces 738C】Road to Cinema

    http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...

  6. 【Codeforces 738A】Interview with Oleg

    http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...

  7. CodeForces - 662A Gambling Nim

    http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...

  8. CodeForces - 274B Zero Tree

    http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...

  9. CodeForces - 261B Maxim and Restaurant

    http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...

随机推荐

  1. HDOJ--1869--六度分离(用三种算法写的,希望能比較出来他们之间的差别)

    六度分离 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  2. $.ajax 使用详解

    Jquery在异步提交方面封装的很好,直接用AJAX非常麻烦,Jquery大大简化了我们的操作. $.post.$.get是一些简单的方法,如果要处理复杂的逻辑,还是需要用到jQuery.ajax() ...

  3. Java代理(Aop实现的原理)

    经过大牛同事的一句指点立马明确的代理实现方式,Spring Aop应该也是这么去做的.直接上代码 实如今Car的run方法之前调用star方法,在run方法之后调用stop方法. Car类 packa ...

  4. Yii2 behaviors中verbs access的一些理解

    public function behaviors() { return ArrayHelper::merge(parent::behaviors(), [ 'verbs' => [ 'clas ...

  5. UDP 端到端

    创建发送端 1.建立DatagramSocket对象,该端点建立,系统会随机分配一个端口,如果不想随机分配,可手动指定. 2.将数据进行packet封装,必须指定目的地址和端口. 3.通过socket ...

  6. FAT和FAT32文件系统的原理

    [转自] http://www.sjhf.net/Article/sjhfdoc/200404/1.html 一.硬盘的物理结构:     硬盘存储数据是根据电.磁转换原理实现的.硬盘由一个或几个表面 ...

  7. 对soc-audio体系snd_soc_machine和snd_soc_dai_link简单理解

    ASOC (ALSA system on chip)              // 主要为嵌入式系统专门开发的sound管理体系结构[luther.gliethttp].Digital Audio ...

  8. URAL1519 Formula 1 —— 插头DP

    题目链接:https://vjudge.net/problem/URAL-1519 1519. Formula 1 Time limit: 1.0 secondMemory limit: 64 MB ...

  9. e.target与e.currentTarget的区别

    在DOM事件对象中有两个属性总是时不时的困扰我,就是target和currentTarget,有时候很迷惑分不清两者的区别,因此有必要把这两个属性好好梳理一下,加深理解,以便日后的查询. MDN中对t ...

  10. 动态的添加ImageView到LinearLayout中并居中显示

    ImageView imageView = new ImageView(mActivity); imageView.setImageResource(R.mipmap.gengduo); Linear ...