双倍经验题

由于我先做的 P6754,所以一切思路基于 P6754 的题目

“ P6754 这题就是 P3413 的究极弱化版 ” --By Aliemo.


P6754 Description

在给定的 \([a,b]\) 区间内求长度 \(\ge\) \(2\) 的非回文串的个数


Solution

设 \(f[i][j][k]\) 表示长度为 \(i\),最高位为 \(j\) ,次高位为 \(k\) 的非回文串的个数

显然有状态转移方程式

\[f[i][j][k]=\sum_{j/k/l=0}^9f[i-1][k][l]\mid j!=k\&\&j!=l\&\&k!=l
\]

对于答案的统计,就是在求出所有的非回文串个数后,通过给定的边界来判断

对于 \(ans_{l,r}\) 可以转化为 \(ans_{1,r}-ans_{1,l-1}\)


注意,本题的求解,对于区间端点的处理,最好将其转化为字符串操作

便于求非回文串的个数

像这样

for(int i = len;i >= 1;i --) {
a[i] = x[len - i] - '0';
sum = sum * 10 + a[i];
}

其他的注意事项放在代码里


Code

#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<algorithm>
#include<iostream>
#include<cstring>
#define int long long
#define rr register using namespace std; char A[1010],B[1010];
int f[1010][20][20];
int a[1010]; int read(){
int s=0,w=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-') w=1;ch=getchar();}
while(ch>='0'&&ch<='9') s=(s<<1)+(s<<3)+ch-'0',ch=getchar();
return s*w;
} void init(){
for(rr int i=2;i<=1000;i++)
for(rr int j=0;j<=9;j++)
for(rr int k=0;k<=9;k++){
if(j==k) continue;
for(rr int l=0;l<=9;l++)
if(k!=l&&j!=l) f[i][j][k]+=f[i-1][k][l];//
if(i==2) f[i][j][k]++;
}
} int solve(char x[]){
bool t=1;memset(a,0,sizeof a);
int ans=0,cnt=0,sum=0,len=strlen(x),ll1=-1,ll2=-1;
for(rr int i=len;i>=1;i--){a[i]=x[len-i]-'0';sum=sum*10+a[i];}
sum++;ans+=10;if(len==1) return sum;//长度为 1 的 10 个数直接加//如果长度为 1 ,不符合规定
for(rr int i=2;i<len;i++)
for(rr int j=1;j<=9;j++)//排除前导 0
for(rr int k=0;k<=9;k++)
ans+=f[i][j][k];
for(rr int i=len;i>=2;i--){
for(rr int j=0;j<a[i];j++){
if(i==len&&j==0) continue;
for(rr int k=0;k<=9;k++)
if(j!=k&&ll1!=k&&ll1!=j&&ll2!=j) ans+=f[i][j][k];
}
if(ll1==a[i]||ll2==a[i]){t=0;break;}//判断前一位与前两位
ll2=ll1;ll1=a[i];
}
if(t==1)for(rr int i=0;i<=a[1];i++)if(i!=ll1&&i!=ll2)ans++;//最后一位单独处理
return ans;
} signed main(){
init();cin>>A;cin>>B;
int Ans=solve(B)-solve(A);
int len=strlen(A),vis=0;
for(rr int i=1;i<len;i++)
if(A[i]==A[i-1]||(A[i]==A[i-2]&&i>1)){vis=1;break;}
if(!vis) Ans++;printf("%lld",Ans);
return 0;
}


P3413 Description

在给定的 \([a,b]\) 区间内求长度 \(\ge\) \(2\) 的非回文串的个数


Solution

按照上面的思路,比较两位上相同的

比较麻烦

换个角度,如果用总串数减去非回文串数,那不就是回文串数了


思考过程与原理同上

注意取模

代码一改就行


Code

#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<algorithm>
#include<iostream>
#include<cstring>
#define int long long
#define rr register
#define Mod 1000000007 using namespace std; char A[1010],B[1010];
int f[1010][20][20];
int a[1010]; int read(){
int s=0,w=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-') w=1;ch=getchar();}
while(ch>='0'&&ch<='9') s=(s<<1)+(s<<3)+ch-'0',ch=getchar();
return s*w;
} void init(){
for(rr int i=2;i<=1000;i++)
for(rr int j=0;j<=9;j++)
for(rr int k=0;k<=9;k++){
if(j==k) continue;
for(rr int l=0;l<=9;l++)
if(k!=l&&j!=l) f[i][j][k]=(f[i][j][k]+f[i-1][k][l])%Mod;
if(i==2) f[i][j][k]=(f[i][j][k]+1)%Mod;
}
} int solve(char x[]){//sum 统计总串数,减去 ans 即可
bool t=1;memset(a,0,sizeof a);
int ans=0,cnt=0,sum=0,len=strlen(x),ll1=-1,ll2=-1;
for(rr int i=len;i>=1;i--){a[i]=x[len-i]-'0';sum=(sum*10+a[i])%Mod;}
sum++;ans+=10;if(len==1) return 0;
for(rr int i=2;i<len;i++)
for(rr int j=1;j<=9;j++)
for(rr int k=0;k<=9;k++)
ans=(ans+f[i][j][k])%Mod;
for(rr int i=len;i>=2;i--){
for(rr int j=0;j<a[i];j++){
if(i==len&&j==0) continue;
for(rr int k=0;k<=9;k++)
if(j!=k&&ll1!=k&&ll1!=j&&ll2!=j) ans=(ans+f[i][j][k])%Mod;
}
if(ll1==a[i]||ll2==a[i]){t=0;break;}
ll2=ll1;ll1=a[i];
}
if(t==1)for(rr int i=0;i<=a[1];i++)if(i!=ll1&&i!=ll2)ans=(ans+1)%Mod;
return (sum-ans+Mod)%Mod;
} signed main(){
init();cin>>A;cin>>B;
int len=strlen(A),Ans=solve(B)-solve(A);
for(rr int i=1;i<len;i++)
if(A[i]==A[i-1]||(A[i]==A[i-2]&&i>1)){Ans=(Ans+1)%Mod;break;}
printf("%lld",(Ans+Mod)%Mod);
return 0;
}

洛谷P3413 P6754的更多相关文章

  1. 洛谷P3413 SAC#1 - 萌数 题解 数位DP

    题目链接:https://www.luogu.com.cn/problem/P3413 题目大意: 定义萌数指:满足"存在长度至少为2的回文子串"的数. 求区间 \([L,R]\) ...

  2. [洛谷P3413]SAC#1 - 萌数

    题目大意:求$[l,r](0\leqslant l<r< 10^{1001})$中存在长度至少为$2$的回文串的数字数 题解:数位$DP$,发现如果有回文串,若长度为偶数,一定有两个相同的 ...

  3. 洛谷P3413 SAC#1 - 萌数(数位dp)

    题目描述 辣鸡蒟蒻SOL是一个傻逼,他居然觉得数很萌! 好在在他眼里,并不是所有数都是萌的.只有满足“存在长度至少为2的回文子串”的数是萌的——也就是说,101是萌的,因为101本身就是一个回文数:1 ...

  4. 洛谷 P3413 SAC#1 - 萌数

    题意简述 求l~r之间存在长度至少为2的回文子串的正整数的个数 题解思路 数位DP 注意到有偶数长度的回文串必有长度为2的回文串,有奇数长度的回文串必有长度为3的回文串 所以只需判断与前一位,前两位是 ...

  5. 【洛谷P3413】萌数

    题目大意:求区间 [l,r] 内萌数的个数,其中萌数定义为数位中存在长度至少为 2 的回文子串的数字. 题解:l, r 都是 1000 位级别的数字,显然是一道数位 dp 的题目,暴力直接去世. 发现 ...

  6. 洛谷$P3413$ 萌数 $SAC\#1$ 数位$dp$

    正解:数位$dp$ 解题报告: 传送门! 非常套路的数位$dp$,,,?打起来就很爽昂,,,不要脑子,我就很爱嘻嘻嘻 然后$[l,r]$这种问题不显然考虑套路地搞成$[1,l-1]$和$[1,r]$嘛 ...

  7. 洛谷 P3413 【萌数】

    敲完这篇题解,我就,我就,我就,嗯,好,就这样吧... 思路分析: 首先我们要知道一个回文串的性质--假如说一个[l-1,r+1]的串是回文的,那么[l,r]一定也是回文的. 所以我们只要记录前一个数 ...

  8. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  9. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

随机推荐

  1. 【原创】Linux PCI驱动框架分析(二)

    背 景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本 ...

  2. setHeader方法的参数说明

    转自:http://blog.sina.com.cn/s/blog_510fdc8b0100v8sg.html response.setHeader 是用来设置返回页面的头 meta 信息, 使用时 ...

  3. 痞子衡嵌入式:MCUXpresso IDE下添加新路径下源文件进工程编译的方法

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下添加新路径下源文件进工程编译的方法. 接着上篇文章 <MCUXpresso IDE下SDK工程导入与 ...

  4. vue中的插值操作

    mustache语法 1.将data的文本数据插入至html语句中,使用mustache语法. v-once指令 2.在某些情况下,我们不希望界面随意的跟随改变,这个时候我们可以使用v-once的指令 ...

  5. TurtleBot3使用课程-第三节b(北京智能佳)

    目录 1.使用TurtleBot3机械手运行SLAM 2 1.1 roscore运行 2 1.2 准备行动 3 1.3 运行SLAM节点 3 1.4 运行turtlebot3_teleop_key节点 ...

  6. 如何创建 mapbox 精灵图

    前面文章介绍了如何在本地发布OSM数据,并使用 maputnik 自定义 mapbox 格式的地图样式. 在使用 maputnik 配图时,如果想要使用自己的图片作为地图符号,就需要制作精灵图. ma ...

  7. 实现一个简单的 Linux Shell(C++)

    Implement a simple command interpreter in Linux. The interpreter should: support both internal and e ...

  8. Burp suite的系列介绍 (1)

    前言 为了进行Web安全方面的学习,Burp suite是必备的工具之一,我们将会从多个模块进行逐步的学习. Burp suite的应用场景 1.HTTP服务端接口测试. 2.HTTP客户端和HTTP ...

  9. MySQL常用的数据类型和字段属性

    数据类型 数值 tinyint 十分小的数据 1个字节 smallint 较小的数据 2个字节 mediumint 中等大小的数据 3个字节 int 标准的整数 4个字节 常用 bigint 较大的数 ...

  10. 【Problems】MySQL5.7 datetime 默认值设为‘0000-00-00 00:00:00'值出错

    记录 MySQL5.7 datetime 默认值设为'0000-00-00 00:00:00'值出错 我的MySQL版本 mysql --version 5.7.28 C:\Users\x1c> ...