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. EnumChildWindows

    EnumChildWindows 函数功能:枚举一个父窗口的所有子窗口. 函数原型:BOOL EnumChildWindows(HWND hWndParent,WNDENUMPROC lpEnumFu ...

  2. var和let的区别(详解)

    1. 作用域 通过var定义的变量,作用域是整个封闭函数,是全域的 . 通过let定义的变量,作用域是在块级或是子块中. function varTest() { var x = 1; if (tru ...

  3. Android系统设置Android adb 开关的方法【转】

    本文转载自:http://www.wxtlife.com/2015/11/24/Android-set-adb-status/ 想第一时间获取我的最新文章,请关注公众号: 技术特工队 在整机系统开发中 ...

  4. YTU 2455: Pefect 数字

    2455: Pefect 数字 时间限制: 1 Sec  内存限制: 128 MB 提交: 749  解决: 146 题目描述 小明和小林做数字游戏,他们的游戏规则如下: 小明说出一个数字n,小林说出 ...

  5. 2013级新生程序设计基础竞赛-正式赛 F 异或最大值 解题报告

    F - 异或最大值 Time Limit: 2000/1000MS (Java/Others)      Memory Limit: 128000/64000KB (Java/Others) Subm ...

  6. laya在微信小游戏中加载BitmapFont失效的问题

    发布为微信小游戏后,在微信工具中测试时总是提示加载retry to load TheRed.fnt,并以error告终.由于没有任何出错信息,无奈之下只好阅读源码.对BitmapFont的处理分为两个 ...

  7. Brackets(区间dp)

    Brackets Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8017   Accepted: 4257 Descript ...

  8. javascript之this指向

    情况一: 如果一个函数中有this,但是没有被上一级调用,this指向window 例: function a(){ var num='11'; console.log(this.num);  //u ...

  9. Watir: Watir webdriver对JS 弹出框的操作现在非常简单。

    以下代码支持Firefox,IE,Chrome require 'watir-webdriver' #require "watir-webdriver/extensions/alerts&q ...

  10. 【转】Chrome headless 模式

    原文地址: http://www.cnblogs.com/fnng/p/7797839.html 我们在通过Selenium运行自动化测试时,必须要启动浏览器,浏览器的启动与关闭必然会影响执行效率,而 ...