题目大意:求区间 [l,r] 内萌数的个数,其中萌数定义为数位中存在长度至少为 2 的回文子串的数字。

题解:l, r 都是 1000 位级别的数字,显然是一道数位 dp 的题目,暴力直接去世。

发现萌数的定义是一个存在性命题,并不好去求解。利用补集思想,将存在性命题转化成任意性命题,即:求区间 [l,r] 中有多少个数不是萌数。发现只需维护当前位的前两位的数值即可判断是不是萌数,即:若一个数是萌数,当且仅当存在形如 "aa" 或 "aba" 类型的子串。利用数位 dp 统计即可。

另外,注意数组下标,若是负数需要单独判断一下。

代码如下

#include <bits/stdc++.h>
using namespace std;
const int mod=1e9+7;
typedef long long LL; char l[1010],r[1010];
int digit[1010],tot;
LL dp[1010][10][10]; LL dfs(int cur,int pre2,int pre1,bool lead,bool limit){
if(cur==tot+1)return 1;
if(!limit&&!lead&&dp[cur][pre2][pre1]!=-1&&pre2!=-1&&pre1!=-1)return dp[cur][pre2][pre1];
LL ret=0;
int bit=limit?digit[cur]:9;
for(int i=0;i<=bit;i++){
if(!i&&lead)ret=(ret+dfs(cur+1,-1,-1,1,limit&&i==bit))%mod;
else if(i&&lead)ret=(ret+dfs(cur+1,-1,i,0,limit&&i==bit))%mod;
else{
if(i==pre2||i==pre1)continue;
ret=(ret+dfs(cur+1,pre1,i,0,limit&&i==bit))%mod;
}
}
if(!limit&&!lead&&pre2!=-1&&pre1!=-1)dp[cur][pre2][pre1]=ret;
return ret;
}
LL part(char *s){
tot=strlen(s+1);
memset(digit,0,sizeof(digit));
for(int i=1;i<=tot;i++)digit[i]=s[i]-'0';
memset(dp,-1,sizeof(dp));
return dfs(1,-1,-1,1,1);
}
void solve(){
LL ret=part(r)-part(l)+1;
int lenl=strlen(l+1),lenr=strlen(r+1);
for(int i=2;i<=lenl;i++){
if(l[i]==l[i-1]||l[i]==l[i-2]){
--ret;
break;
}
}
ret=(ret+mod)%mod; LL retl=0,retr=0;
for(int i=1;i<=lenl;i++)retl=(retl*10+l[i]-'0')%mod;
for(int i=1;i<=lenr;i++)retr=(retr*10+r[i]-'0')%mod;
LL ans=((retr-retl+1-ret)%mod+mod)%mod; printf("%lld\n",ans);
}
int main(){
scanf("%s%s",l+1,r+1);
solve();
return 0;
}

最新文章

  1. spider RPC开发指南
  2. js_原型
  3. Convert a given Binary Tree to Doubly Linked List
  4. AudioQueue语音流 speex压缩 实时通讯 对讲机
  5. 推荐个Java代码质量检测的利器 —— FindBugs
  6. C#_自动化测试 (四) 自动卸载软件
  7. ie8 background css没有显示?——都是空格惹的祸
  8. Sublime Text 2 自动开启换行 Word Wrap
  9. ThinkPHP多应用/项目配置技巧(使用同一配置文件)--(十六)
  10. OSQA的配置
  11. 【BZOJ4013】[HNOI2015]实验比较(动态规划)
  12. MySQL入门命令
  13. sql server数据库文件的迁移(mdf&amp;ldf文件)
  14. Oracle 导出的表不全,以及数据库版本不同导入报错
  15. HDU 2191 - 单调队列优化多重背包
  16. MySQL存储引擎对比
  17. Python学习(004)-字典{}
  18. Dubbo使用心得2
  19. BZOJ4070 [Apio2015]雅加达的摩天楼 【分块 + 最短路】
  20. 在web项目下注册MySQL数据库驱动失败

热门文章

  1. VueLoaderPlugin作用
  2. SQLServer 断开指定会话
  3. python学习之生函数名的理解
  4. 如何解决idea本身的乱码以及解决代码中出现的乱码?
  5. Android自动化测试(UiAutomator)
  6. python 并发编程 多线程 GIL与多线程
  7. postgresql 用 like 可以 复制结构包括主键约束
  8. python——列表方法
  9. JS中property与attribute的区别
  10. django-xadmin使用