CodeForces 628D Magic Numbers (数位dp)
题意:找到[a, b]符合下列要求的数的个数。
1、该数字能被m整除
2、该数字奇数位全不为d,偶数位全为d
分析:
1、dp[当前的位数][截止到当前位所形成的数对m取余的结果][当前数位上的数字是否到达了上限]
2、对于第三维的上限,例如一个数字是54362,那么如果前四位是5436,那么前四位都到达了上限,第五位可以从0枚举所有可能,例如如果第五位是1,那么就没到达上限,如果是6就到达了上限,简而言之,就是个匹配的问题。
需要注意的是,上限不是指第二位数字只能是0~4,第三位数字只能是0~3,如果前三位是495,虽然没到达上限,但是也是一种可能的情况
3、枚举余数,截止到某一位所形成的新的数字,是由上一位的余数计算的来,所以加上第i位所形成的有新余数的新数字应该继承前i-1为所形成的有旧余数的数字的情况数
4、大整数取余,从最左位起,设ans = s[i - 1] - '0',分别ans = (ans * 10 + s[i] - '0')% m,计算的结果ans是截止到该位所形成的数字对m取余的结果,由此可知,计算到最右位以后,若该数能被m整除,ans应为0
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cctype>
#include<cmath>
#include<iostream>
#include<sstream>
#include<iterator>
#include<algorithm>
#include<string>
#include<vector>
#include<set>
#include<map>
#include<stack>
#include<deque>
#include<queue>
#include<list>
#define Min(a, b) a < b ? a : b
#define Max(a, b) a < b ? b : a
typedef long long ll;
typedef unsigned long long llu;
const int INT_INF = 0x3f3f3f3f;
const int INT_M_INF = 0x7f7f7f7f;
const ll LL_INF = 0x3f3f3f3f3f3f3f3f;
const ll LL_M_INF = 0x7f7f7f7f7f7f7f7f;
const int dr[] = {, , -, };
const int dc[] = {-, , , };
const double pi = acos(-1.0);
const double eps = 1e-;
const int MOD = 1e9 + ;
const int MAXN = + ;
const int MAXT = + ;
using namespace std;
char a[MAXN], b[MAXN];
int dp[MAXN][MAXN][];
int m, d;
int solve(char *s){//只能计算相同位数范围内的,例如若s=1956,则只计算1000到1956范围内满足条件的
memset(dp, , sizeof dp);
int len = strlen(s);
//初始化第一位
for(int i = ; i < ; ++i){
if(i == d) continue;
if(i < s[] - '') ++dp[][i % m][];
else if(i == s[] - '') ++dp[][i % m][];
}
for(int i = ; i < len; ++i){
if(i & ){//偶数位一定为d
for(int j = ; j < m; ++j){
int tmp = (j * + d) % m;//假设截止到该位所形成的数字为y,而原串截止到该位所形成的数字是5436
(dp[i][tmp][] += dp[i - ][j][]) %= MOD;//y为4989
if(d < s[i] - '') (dp[i][tmp][] += dp[i - ][j][]) %= MOD;//y为5431
else if(d == s[i] - '') (dp[i][tmp][] += dp[i - ][j][]) %= MOD;//y为5436
}
}
else{
for(int j = ; j < ; ++j){//奇数位可能是各种数字,所以枚举
if(j == d) continue;
for(int k = ; k < m; ++k){
int tmp = (k * + j) % m;
(dp[i][tmp][] += dp[i - ][k][]) %= MOD;//分析中第2条的情况,形成的数字由于之前的位都没达到上限,所以这一位的数字无论多大,截止到该位所形成的数字都不会大于上限
if(j < s[i] - '') (dp[i][tmp][] += dp[i - ][k][]) %= MOD;//之前的位到达上限,该位没到达
else if(j == s[i] - '') (dp[i][tmp][] += dp[i - ][k][]) %= MOD;//之前的位到达上限,该位也到达
}
}
}
}
return (dp[len - ][][] + dp[len - ][][]);//只要是截止到len-1位,余数为0的情况都满足,dp[len - 1][0][1]就是s是否满足条件
}
int judge(char *s){//判断该数字是否满足条件
int ans = ;
for(int i = ; s[i]; ++i){
if(i % == && s[i] - '' == d) return ;
if(i & && s[i] - '' != d) return ;
ans = (ans * + s[i] - '') % m;
}
return (ans == ) ? : ;
}
int main(){
scanf("%d%d%s%s", &m, &d, a, b);
int ans = solve(b) - solve(a) + judge(a);//因为solve只能计算相同位数范围内的,因此不能solve(b) - solve(a - 1),假设a为1000,a-1为999
printf("%d\n", (ans + MOD) % MOD);//注意+MOD,因为solve是MOD取余的结果,可能造成solve(b) - solve(a)为负数
return ;
}
CodeForces 628D Magic Numbers (数位dp)的更多相关文章
- Educational Codeforces Round 8 D. Magic Numbers 数位DP
D. Magic Numbers 题目连接: http://www.codeforces.com/contest/628/problem/D Description Consider the deci ...
- CodeForces 628 D Magic Numbers 数位DP
Magic Numbers 题意: 题意比较难读:首先对于一个串来说, 如果他是d-串, 那么他的第偶数个字符都是是d,第奇数个字符都不是d. 然后求[L, R]里面的多少个数是d-串,且是m的倍数. ...
- codeforces 55D - Beautiful numbers(数位DP+离散化)
D. Beautiful numbers time limit per test 4 seconds memory limit per test 256 megabytes input standar ...
- 【CF628D】Magic Numbers 数位DP
[CF628D]Magic Numbers 题意:求[a,b]中,偶数位的数字都是d,其余为数字都不是d,且能被m整除的数的个数(这里的偶数位是的是从高位往低位数的偶数位).$a,b<10^{2 ...
- CodeForces - 55D - Beautiful numbers(数位DP,离散化)
链接: https://vjudge.net/problem/CodeForces-55D 题意: Volodya is an odd boy and his taste is strange as ...
- Codeforces - 55D Beautiful numbers (数位dp+数论)
题意:求[L,R](1<=L<=R<=9e18)区间中所有能被自己数位上的非零数整除的数的个数 分析:丛数据量可以分析出是用数位dp求解,区间个数可以转化为sum(R)-sum(L- ...
- CodeForces - 55D Beautiful numbers —— 数位DP
题目链接:https://vjudge.net/problem/CodeForces-55D D. Beautiful numbers time limit per test 4 seconds me ...
- Codeforces 628D Magic Numbers
题意: 求在[a,b](a,b不含前导0)中的d−magic数中有多少个是m的倍数. 分析: 计数dp Let's call a number d-magic if digit d appears i ...
- codeforces628D. Magic Numbers (数位dp)
Consider the decimal presentation of an integer. Let's call a number d-magic if digit d appears in d ...
随机推荐
- 分布式存储系统sheepdog
Sheepdog,是由NTT的3名日本研究员开发的开源项目,主要用来为虚拟机提供块设备. 其架构例如以下: 以下,我们将从架构.模块等几个方面来介绍下: 一.架构图 如上图: 採用无中心节点的全对称架 ...
- Javascript教程:AngularJS的五个超酷特性
AngularJS是一个超棒的javascript框架,不单单对于开发人员来说非常有吸引力,对于UI设计师来说也同样出色.在这篇教程中,我们将简单的介绍AngularJS几个重量级必备特性,并且介绍它 ...
- 1.5.1 Analyzers,Tokenizers,Filters概述
字段分析器(Analyzers)即用于文档索引也用于查询.一个分析器检查字段的文本,并生成一个token流.分析器可能是一个单独的类,也可能是一系列的tokenizer和filter的组合. 分词器把 ...
- Joynet示例:知乎爬虫(搜索关键字相关回答,并下载其中的---图(mei)片(nv))
先贴爬虫程序下载地址:http://pan.baidu.com/s/1c2lxl1e 下载解压后 可直接运行 其中的 run.bat:或者你手动打开命令行执行:Joynet examples\Spid ...
- nginx 代理服务器 502错误
在centos系统下,nginx做代理服务器总是出现502错误,百度各种搜索,出来的答案基本都是一样的,也不知道大家 从哪抄的,问题也没有解决,最后还是从谷歌找到的答案: 总归还是centos系统的问 ...
- Umbraco列表分页
展示型文章经常会遇到分页的问题,以下是我的解决方法: ; ; int.TryParse(Request.QueryString["page"], out page); var to ...
- hdu 3966 树链剖分
思路:树链剖分入门题,我这门入得好苦啊,程序很快写出来了,可是在LCA过程中把update函数里的左右边界位置写反了,一直RE到死. #pragma comment(linker, "/ST ...
- a标签中使用img后的高度多了4px
前两天,在做一个网站的时候,发现a标签中使用img后的高度多了4px,各种纠结. 最后,仔细分析,终于找到原因了,因为img是行内元素,默认display: inline; 它与文本的默认行为类似,下 ...
- 默认样式重置 (css reset)
body,p,h1,h2,h3,h4,h5,h6,dl,dd,t{margin:0; font-size:12px;/* font-family:XX; */} ol,ul{list-style:no ...
- static和public
static:静态. 可以设置:静态类.静态变量.静态方法. 没有使用static修饰的成员为实例成员. 静态成员的使用:通过类名. 1.不加static修饰的成员是对象成员,归每个对象所 ...