题意:d magic number(0<=d<9)的意思就是一个数,从最高位开始奇数位不是d,偶数位是d

题目问,给a,b,m,d(a<=b,m<2000)问,a,b之间有多少个数满足既是d magic number,又可以被m整除

a,b的范围很大,都是2000位,且a,b的位数一样,这一点很重要

分析:这题一看又有取模,又是大整数,那肯定是要用数位dp做,

通常的数位dp,我们要解决(0,x)的区间中的答案,但是这个题不需要,

注意刚才我说过一点,a,b是位数相同的整数,假设solve()函数能解决x到和它同位的最小整数的区间范围内的答案

那么最终答案,就是solve(b)-solve(a)+is(a),

这样我们的工作就简单了,不需要统计位数比它小的数

我们从高位开始进行dp

下面定义状态

1: dp[i][j][1],代表现在处理到第 i 位 且前缀 i 位形成的整数n%m=j 的 方案数,且现在形成的整数等于上限

2: dp[i][j][0],代表现在处理到第 i 位 且前缀 i 位形成的整数n%m=j 的 方案数,且现在形成的整数小于上限

那么状态转移方程就很好想了

设字符串长度为n  那么时间复杂度是O(nm)的

#include <cstdio>
#include <iostream>
#include <cstring>
using namespace std;
typedef long long LL;
const int N = 2e3+;
const int mod = 1e9+;
int dp[N][N][],num[N],m,d;
char a[N],b[N];
int solve(char *s)
{
int l=strlen(s+);
memset(dp,,sizeof(dp));
for(int i=; i<=l; ++i)
num[i]=s[i]-'';
for(int i=; i<=; ++i)
{
if(i==d)continue;
if(i<num[])++dp[][i%m][];
else if(i==num[])++dp[][i%m][];
}
for(int i=; i<=l; ++i)
{
if(i%==)
{
for(int j=; j<m; ++j)
{
int cur=(j*+d)%m;
dp[i][cur][]=(dp[i][cur][]+dp[i-][j][])%mod;
if(d<num[i])
dp[i][cur][]=(dp[i][cur][]+dp[i-][j][])%mod;
else if(num[i]==d)
dp[i][cur][]=(dp[i][cur][]+dp[i-][j][])%mod;
}
}
else
{
for(int k=; k<; ++k)
{
if(k==d)continue;
for(int j=; j<m; ++j)
{
int cur=(j*+k)%m;
dp[i][cur][]=(dp[i][cur][]+dp[i-][j][])%mod;
if(k<num[i])
dp[i][cur][]=(dp[i][cur][]+dp[i-][j][])%mod;
else if(k==num[i])
dp[i][cur][]=(dp[i][cur][]+dp[i-][j][])%mod;
}
}
}
}
return (dp[l][][]+dp[l][][])%mod;
}
int judge(char *s)
{
int l=strlen(s+),sum=;
for(int i=;i<=l;++i)
{
int x=s[i]-'';
if(i%&&x==d)return ;
if(!(i%)&&x!=d)return ;
sum=(sum*+x)%m;
}
if(!sum)return ;
return ;
}
int main()
{
scanf("%d%d%s%s",&m,&d,a+,b+);
int ans=(solve(b)-solve(a)+judge(a)+mod)%mod;
printf("%d\n",ans);
return ;
}

Codeforces 628D 数位dp的更多相关文章

  1. Codeforces 55D (数位DP+离散化+数论)

    题目链接: http://poj.org/problem?id=2117 题目大意:统计一个范围内数的个数,要求该数能被各位上的数整除.范围2^64. 解题思路: 一开始SB地开了10维数组记录情况. ...

  2. codeforces 401D (数位DP)

    思路:很明显的数位dp,设dp[i][j] 表示选取数字的状态为i,模m等于j的数的个数,那么最后的答案就是dp[(1<<n)-1][0].状态转移方程就是,dp[i|(1<< ...

  3. Travelling Salesman and Special Numbers CodeForces - 914C (数位dp)

    大意: 对于一个数$x$, 每次操作可将$x$变为$x$二进制中1的个数 定义经过k次操作变为1的数为好数, 求$[1,n]$中有多少个好数 注意到n二进制位最大1000位, 经过一次操作后一定变为1 ...

  4. Codeforces - 914C 数位DP

    题意有点难以描述,简略的就是给定一个二进制\(n\),每一步操作能使\(n\)的位为1的数的和转化为一个十进制,然后转化为该数的二进制再进行相同的操作 查询\([0,n]\)中操作数恰好为\(k\)的 ...

  5. codeforces 55D 数位dp

    D. Beautiful numbers time limit per test 4 seconds memory limit per test 256 megabytes input standar ...

  6. Shovel Sale CodeForces - 899D (数位dp)

    大意: n把铲子, 价格1,2,3,...n, 求有多少个二元组(x,y), 满足x+y末尾数字9的个数最多. 枚举最高位, 转化为从[1,n]中选出多少个二元组和为$x$, 枚举较小的数 若$n\g ...

  7. codeforces Hill Number 数位dp

    http://www.codeforces.com/gym/100827/attachments Hill Number Time Limits:  5000 MS   Memory Limits: ...

  8. codeforces 55D - Beautiful numbers(数位DP+离散化)

    D. Beautiful numbers time limit per test 4 seconds memory limit per test 256 megabytes input standar ...

  9. Codeforces Gym 100231L Intervals 数位DP

    Intervals 题目连接: http://codeforces.com/gym/100231/attachments Description Start with an integer, N0, ...

随机推荐

  1. (转载)猫都能学会的Unity3D Shader入门指南(一)

    原文地址 http://onevcat.com/2013/07/shader-tutorial-1/ 动机 自己使用Unity3D也有一段时间了,但是很多时候是流于表面,更多地是把这个引擎简单地用作脚 ...

  2. 【BZOJ2199】 [Usaco2011 Jan]奶牛议会

    Description 由于对Farmer John的领导感到极其不悦,奶牛们退出了农场,组建了奶牛议会.议会以“每头牛 都可以获得自己想要的”为原则,建立了下面的投票系统: M只到场的奶牛 (1 & ...

  3. sharepoint 2010 masterpage中必须的Content PlaceHolder

    Professional SharePoint 2010 Branding and Use

  4. CocoaPods - 在 Mac 中的生与死

    1. 集成 Cocoapod: 1.1 安装 ruby环境 mac 系统默认有 Ruby 环境, 通过 $ ruby -v 可以查看当前的 Ruby 版本.  如果 Ruby 版本过低可以通过 rvm ...

  5. Webstorm10.0.4注册码

    分享几个Webstorm10的注册码: (1) user name :EMBRACE ===== LICENSE BEGIN =====17739-1204201000002KkN!4z2O8JEyj ...

  6. [转载]MVC3缓存:使用页面缓存

    在以前的WebForm的开发中,在页面的头部加上OutputCache即可启用页面缓存,而在MVC3中,使用了Razor模板引擎的话,该如何使用页面缓存呢?如何启用 在MVC3中要如果要启用页面缓存, ...

  7. Deep Learning and the Triumph of Empiricism

    Deep Learning and the Triumph of Empiricism By Zachary Chase Lipton, July 2015 Deep learning is now ...

  8. CrackMe_001

    本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注册机的东西. 其中,文章中按照如下逻辑编排(解决如 ...

  9. Data transfer object

    Data transfer object (DTO) is a design pattern used to transfer data between software application su ...

  10. codeforces #310 div1 C

    操作无论是U还是L,都会使原图形分裂成两个图形,且两个图形的操作互不影响 我们又发现由于操作点只可能在下斜线上,如果将操作按x排序 那么无论是U还是L,都会将操作序列完整分割成两半,且两个操作序列互不 ...