【洛谷P3413】萌数
题目大意:求区间 [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;
}
【洛谷P3413】萌数的更多相关文章
- 洛谷$P3413$ 萌数 $SAC\#1$ 数位$dp$
正解:数位$dp$ 解题报告: 传送门! 非常套路的数位$dp$,,,?打起来就很爽昂,,,不要脑子,我就很爱嘻嘻嘻 然后$[l,r]$这种问题不显然考虑套路地搞成$[1,l-1]$和$[1,r]$嘛 ...
- 洛谷P1102 A-B数对
洛谷P1102 A-B数对 https://www.luogu.org/problem/show?pid=1102 题目描述 出题是一件痛苦的事情! 题目看多了也有审美疲劳,于是我舍弃了大家所熟悉的A ...
- 洛谷P1288 取数游戏II(博弈)
洛谷P1288 取数游戏II 先手必胜的条件需要满足如下中至少 \(1\) 条: 从初始位置向左走到第一个 \(0\) 的位置,经过边的数目为偶数(包含 \(0\) 这条边). 从初始位置向右走到第一 ...
- 洛谷P3413 SAC#1 - 萌数 题解 数位DP
题目链接:https://www.luogu.com.cn/problem/P3413 题目大意: 定义萌数指:满足"存在长度至少为2的回文子串"的数. 求区间 \([L,R]\) ...
- 洛谷P3413 SAC#1 - 萌数(数位dp)
题目描述 辣鸡蒟蒻SOL是一个傻逼,他居然觉得数很萌! 好在在他眼里,并不是所有数都是萌的.只有满足“存在长度至少为2的回文子串”的数是萌的——也就是说,101是萌的,因为101本身就是一个回文数:1 ...
- 洛谷 P3413 【萌数】
敲完这篇题解,我就,我就,我就,嗯,好,就这样吧... 思路分析: 首先我们要知道一个回文串的性质--假如说一个[l-1,r+1]的串是回文的,那么[l,r]一定也是回文的. 所以我们只要记录前一个数 ...
- 洛谷 P1392 取数
题面 在做这道题前,先要会他的弱化版(实际一模一样,只是愚蠢的洛谷评测级别差了一档(睿智如姬无夜)) ----------------------------------弱化版------------ ...
- 洛谷——P2421 A-B数对(增强版)
题目背景 woshiren在洛谷刷题,感觉第一题:求两数的和(A+B Problem)太无聊了,于是增加了一题:A-B Problem,难倒了一群小朋友,哈哈. 题目描述 给出N 个从小到大排好序的整 ...
- 洛谷 P5206 - [WC2019]数树(集合反演+NTT)
洛谷题面传送门 神仙多项式+组合数学题,不过还是被我自己想出来了( 首先对于两棵树 \(E_1,E_2\) 而言,为它们填上 \(1\sim y\) 使其合法的方案数显然是 \(y\) 的 \(E_1 ...
随机推荐
- Go语言程序结构
注意:Go语言源码文件编码格式必须是 UTF-8 格式,否则会导致编译器出错. 1.语言变量 a) 指定变量类型,声明后若不赋值,使用默认值. var name string b) 根据值自行判定变量 ...
- prism App.config 配置
<?xml version="1.0" encoding="utf-8" ?> <configuration> <configSe ...
- HttpRunnerManager(二)--使用
参考资料:https://sutune.me/2018/08/05/httprunner/
- java:Springmvc框架3(Validator)
1.springmvcValidator: web.xml: <?xml version="1.0" encoding="UTF-8"?> < ...
- ABAP的smartform赋值
添加文本后, 在输出选项中指定行/列
- Golang的面向对象编程【结构体、方法、继承、接口】
Golang也支持面向对象编程.但与以前学过传统的面向对象编程语言有区别.1)Golang没有类class,Go语言的结构体struct和类class有相似的特性.2)Golang中不存在继承,方法重 ...
- 从git上pull下的代码,执行时提示:ModuleNotFoundError: No module named '......',解决方法如下:
方法一: 如果没有安装,如下: 1.PyCharm : file-> setting->Project interpreter–>package2.右侧有个+ 点击3.进入后 搜索p ...
- 开发维护中遇到问题---eclipse、发版问题
1.jar包冲突问题, [服务器启动service服务器,tomcat也已启动]然后浏览器访问,会出现这样子的问题现象:tomcat什么的启动成功,但是访问时会出现404: 解决方法:先停掉tomca ...
- 百度之星 2019 预赛三 A 最短路 1
题目链接 分析 异或运算满足「三角不等式」. $\forall a, b, c \in \mathbb{Z}_{\ge 0}$,有 $a \xor b \le (a \xor c) + (c \xor ...
- springBoot2.0 Yaml值获取
1. pom.xml添加如下依赖 <dependency> <groupId>org.springframework.boot</groupId> <arti ...