题目链接

题目大意

要你在[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. 【问题记录】—.NetCore 编译问题

    最近在协助验证Jenkins自动编译发布时,对一些.Net Core编译问题进行了解决:特记录一下 一.编译生成netcoreapp目录问题 问题现象 .net core项目编译输出目录总是包含在[n ...

  2. 「newbee-mall新蜂商城开源啦」 页面优化,最新版 wangEditor 富文本编辑器整合案例

    大家比较关心的新蜂商城 Vue3 版本目前已经开发了大部分内容,相信很快就能够开源出来让大家尝鲜了,先让大家看看当前的开发进度: 开源仓库地址为 https://github.com/newbee-l ...

  3. Java SPI 机制实现解耦与本地化

    SPI 是 Java 提供的一种服务加载方式,全名为 Service Provider Interface,可以避免在 Java 代码中写死服务的提供者,而是通过 SPI 服务加载机制进行服务的注册和 ...

  4. CH2101可达性问题

    CH2101可达性问题 拓扑排序应用基础 题意描述 具体见书P95. 给定一个N个点,M条边的有向无环图,问每个点直接或间接可到达的点的数量. 算法分析 书中有详细介绍,这里就不再赘述了. 简而言之就 ...

  5. 浅谈querySelector和getElementById之间的区别

    前言: 最近学到前端一些知识,看到很多视频上许多老师都用的是querySelector而部分老师用的是getElementById,我就很疑惑,这两有啥区别,都是选择器,于是百度了一下明白了,quer ...

  6. 11/6笔记 补充(Redis持久化,RDB&&AOF)

    11/6补充笔记 修改redis-6379.conf里面的save10秒2个数据发生改变 (save 10 2) 修改一次数据不发生改变,修改2次数据才发生改变 继续修改数据,发现还是一样的规律 增删 ...

  7. 常见特征金字塔网络FPN及变体

    好久没有写文章了(对不起我在划水),最近在看北京的租房(真真贵呀). 预告一下,最近无事,根据个人多年的证券操作策略和自己的浅显的AI时间序列的算法知识,还有自己Javascript的现学现卖,在微信 ...

  8. project--客户信息管理系统

    软件设计分析 该软件有三个模块组成:Customer  CustomerList  CustomerView Customer 为实体对象,用来封装客户信息: CustomerList 为 Custo ...

  9. 下载DirectX SDK (June 2010)的地址记录

    从微软官方下载 https://www.microsoft.com/en-us/download/details.aspx?id=6812 下载后截图

  10. ubuntu12.04管理文件系统工具

    ubuntu12.04管理文件系统工具 以前可以自动管理系统盘和移动硬盘,刚重新安装了UBUNTU12.04LTS之后不行了,原来是这个工具: "PCMANFM" 群星_-_偏偏喜 ...