Salazar Slytherin's Locket CodeForces - 855E
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的更多相关文章
- Codeforces 855E - Salazar Slytherin's Locket
855E - Salazar Slytherin's Locket 题意 给出一个区间,问这个区间内有多少个数满足,将这个数转化为某个进制后,所有数的数量都为偶数. 分析 谁能想到 数位DP 的裸题竟 ...
- Codeforces - 65D - Harry Potter and the Sorting Hat - 简单搜索
https://codeforces.com/problemset/problem/65/D 哈利波特!一种新思路的状压记忆化dfs,记得每次dfs用完要减回去.而且一定是要在dfs外部进行加减!防止 ...
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
- CodeForces - 274B Zero Tree
http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...
- CodeForces - 261B Maxim and Restaurant
http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...
随机推荐
- appium部分api
转自:http://www.aichengxu.com/view/41510 使用的语言是java,appium的版本是1.3.4,java-client的版本是java-client-2.1.0,建 ...
- VC断点失败的原因之中的一个
VC断点失败的原因之中的一个 flyfish 2014-10-23 情景 再debug状态下仅仅有一个cpp文件.命中不了断点. 提示 能够 同意源码与原始版本号不同 不採用,防止出现未知的隐患 问题 ...
- linux kfifo移植
先挖个坑,自己慢慢来填. 参考:http://blog.csdn.net/linyt/article/details/5764312 参考:http://www.cnblogs.com/Anker/p ...
- php基础篇:echo 与 print 的区别
在实际使用中, print 和 echo 两者的功能几乎是完全一样.可以这么说,凡是有一个可以使用的地方,另一个也可以使用.但是,两者之间也还是一个非常重要的区别:在 echo 函数中,可以同时输出多 ...
- 进程调度函数schedule()分析
1.功能简述: 最主要作用就是 从就绪进程中选择一个优先级最高的进程来代替当前进程运行. 2.代码分析 schedule(); struct task_struct *tsk = cur ...
- 解决virtualbox安装增强工具失败的问题
virtualbox有个增强工具,安装之后用户体验是非常爽的.但是有些时候在安装增强工具会遇到一些小问题,无非是没有安装gcc,make之类的编译工具或是需要安装kernel*.而我遇到的问题在做了这 ...
- String bulit-in function
tip: 和tuple一样,字符串也是不可变的类型,字符串的内建函数有非常多,我们一一举例来看看他们的作用 下面是用dir(str) 输出的内容: ['__add__', '__class__', ' ...
- hdu 1541 Stars 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1541 题目意思:有 N 颗星星,每颗星星都有各自的等级.给出每颗星星的坐标(x, y),它的等级由所有 ...
- poj 1860 Currency Exchange 解题报告
题目链接:http://poj.org/problem?id=1860 题目意思:给出 N 种 currency, M种兑换方式,Nick 拥有的的currency 编号S 以及他的具体的curren ...
- HDU - 1269 迷宫城堡(有向图的强连通分量)
d.看一个图是不是强连通图 s.求出强连通分量,看看有没有一个强连通分量包含所有点. c.Tarjan /* Tarjan算法 复杂度O(N+M) */ #include<iostream> ...