题目链接

题目大意

要你在[l,r]中找到有多少个数满足\(x\equiv f(x)(mod\; m)\)

\(f(x)=\sum_{i=1}^{k-1} \sum_{j=i+1}^{k}d(x,i)*d(x,j)\)

\(d(x,i)表示x的第i位数\)

题目思路

显然是数位dp,然而这个数位dp不能同时存x%m 和f(x)%m

这样会内存太大存不了,所以存差值即可

还有这个dfs的时候取模只取一次,不然会t,卡常严重

代码

#include<set>
#include<map>
#include<queue>
#include<stack>
#include<cmath>
#include<cstdio>
#include<vector>
#include<string>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<unordered_map>
#define fi first
#define se second
#define debug printf(" I am here\n");
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pii;
const ll INF=0x3f3f3f3f3f3f3f3f;
const int maxn=5e3+5,inf=0x3f3f3f3f,mod=1e9+7;
const double eps=1e-10;
char l[maxn],r[maxn];
int m,base[maxn];
ll dp[maxn][100][100];
int lenl,lenr,num[maxn];
ll dfs(int pos,int pre,int dif,bool flag){
if(pos==0) return dif==0;
if(!flag&&dp[pos][pre][dif]!=-1){
return dp[pos][pre][dif];
}
int lim=flag?num[pos]:9;
ll ans=0;
for(int i=0;i<=lim;i++){
ans=ans+dfs(pos-1,(pre+i)%m,((dif+i*base[pos]-i*pre)%m+m)%m,flag&&i==lim);
}
ans%=mod;
if(!flag){
dp[pos][pre][dif]=ans;
}
return ans;
}
ll solve1(){
for(int i=1;i<=lenr;i++){
num[i]=r[lenr-i+1]-'0';
}
return dfs(lenr,0,0,1);
}
ll solve2(){
for(int i=1;i<=lenl;i++){
num[i]=l[lenl-i+1]-'0';
}
return dfs(lenl,0,0,1);
}
bool check(){
int sum1=0,sum2=0,pre=0;
for(int i=1;i<=lenl;i++){
sum1=(sum1*10+l[i]-'0')%m;//x%m
sum2=(sum2+(l[i]-'0')*pre)%m;// f(x)%m
pre=(pre+l[i]-'0')%m;
}
return sum1==sum2;
}
signed main(){
int _;scanf("%d",&_);
while(_--){
scanf("%s%s",l+1,r+1);
scanf("%d",&m);
lenl=strlen(l+1),lenr=strlen(r+1);
for(int i=1;i<=max(lenl,lenr);i++){
for(int j=0;j<m;j++){
for(int k=0;k<=m;k++){
dp[i][j][k]=-1;
}
}
}
base[1]=1;
for(int i=2;i<=max(lenl,lenr);i++){
base[i]=base[i-1]*10%m;
}
ll ans=((solve1()-solve2()+check())%mod+mod)%mod;
printf("%lld\n",ans);
}
return 0;
}  

2019-2020 ICPC Asia Hong Kong Regional Contest J. Junior Mathematician 题解(数位dp)的更多相关文章

  1. 2019-2020 ICPC Asia Hong Kong Regional Contest

    题解: https://files.cnblogs.com/files/clrs97/19HKEditorial-V1.zip Code:(Part) A. Axis of Symmetry #inc ...

  2. Asia Hong Kong Regional Contest 2019

    A. Axis of Symmetry B. Binary Tree n 的奇偶性决定胜负. C. Constructing Ranches 路径上点权之和大于,极大值两倍,这是路径上点能拼出多边形的 ...

  3. Asia Hong Kong Regional Contest 2016

    A. Colourful Graph 可以在$2n$步之内实现交换任意两个点的颜色,然后就可以构造出方案. #include <bits/stdc++.h> using namespace ...

  4. 2020.5.16-ICPC Central Europe Regional Contest 2019

    A. ABB #include <bits/stdc++.h> using namespace std; #define PB push_back #define ZERO (1e-10) ...

  5. 2016 ACM/ICPC Asia Regional Shenyang Online 1007/HDU 5898 数位dp

    odd-even number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  6. 2020.5.4-ICPC Pacific Northwest Regional Contest 2019

    A. Radio Prize All boring tree-shaped lands are alike, while all exciting tree-shaped lands are exci ...

  7. Gym - 101981J The 2018 ICPC Asia Nanjing Regional Contest J.Prime Game 计数

    题面 题意:1e6的数组(1<a[i]<1e6),     mul (l,r) =l × (l+1) ×...× r,  fac(l,r) 代表 mul(l,r) 中不同素因子的个数,求s ...

  8. 2019 ACM/ICPC Asia Regional shanxia D Miku and Generals (二分图黑白染色+01背包)

    Miku is matchless in the world!” As everyone knows, Nakano Miku is interested in Japanese generals, ...

  9. 2020 ICPC Asia Taipei-Hsinchu Regional Problem H Optimization for UltraNet (二分,最小生成树,dsu计数)

    题意:给你一张图,要你去边,使其成为一个边数为\(n-1\)的树,同时要求树的最小边权最大,如果最小边权最大的情况有多种,那么要求总边权最小.求生成树后的所有简单路径上的最小边权和. 题解:刚开始想写 ...

随机推荐

  1. gulp + angularjs

    示例项目介绍 文中使用的例子是一个基于 Angular.js 实现的网页版 Todo App,在 Github 中下载angular-quickstart.项目代码结构如下 清单 5. 项目目录结构 ...

  2. 关于spring @scope("prorotype") 和 @aspectj 一起用的问题

    前段时间听别人说prototype 模式的bean用@Aspectj做AOP会导致内存泄漏, 于是自己研究了下总结出几点 1.aspectj  如果是采用javac 编译  会动态产生代理类 代理类是 ...

  3. 安装 Homebrew&iterm2&Oh My Zsh

    /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/instal ...

  4. XX-Net 解决IPV6 不稳定,时好时坏。

    一.启动IPV6 1.重置: netsh interface Teredo set state disable netsh interface Teredo set state type=defaul ...

  5. fflush(stdin)和fflush(stdout)

    转自:http://blog.csdn.net/yeyuangen/article/details/6743416 fflush(stdin)即清理标准输入流,把多余的仍未被保存的数据丢掉. fflu ...

  6. visual c++6.0使用VA注意事项

    visual c++6.0使用VA时配置: (1)因为VA安装时会自动检索MSDEV.exe:如果V6安装在XP或者win7系统上,直接安装,添加addin即可: (2)但是如果安装在win8上,V6 ...

  7. keras中的early stopping

    目的:防止过拟合 # early stoppping from keras.callbacks import EarlyStopping early_stopping = EarlyStopping( ...

  8. 基于gin的golang web开发:使用数据库事务

    在前文介绍访问数据库时介绍了github.com/jmoiron/sqlx包,本文基于这个包使用数据库事务. defer 在使用数据库事务之前,首先需要了解go语言的defer关键字.defer是go ...

  9. netfilter内核态与用户态 通信 之 sockopt

    用户态与内核态交互通信的方法不止一种,sockopt是比较方便的一个,写法也简单.缺点就是使用 copy_from_user()/copy_to_user()完成内核和用户的通信, 效率其实不高, 多 ...

  10. minishell的实现

    直接上各个模块的代码,注释都在文档代码中,非常详细,加上最后的Makefile文件完全可以自行运行看懂: main函数一个文件main.c 1 /* 2 minishell实现的功能:简单命令解析.管 ...