P3193 [HNOI2008] GT考试 题解
之前学矩阵乘的时候做的题,当时因为不会,现在填个坑。
头图
是
P3193 [HNOI2008] GT考试
题目大意:
求有多少个长度为
思路:
首先考虑DP,令
那么显然答案为:
状态转移方程为:
其中的
- 与原串中的下一个字符匹配;
- 失配,无法与任何字符相匹配;
- 重新与原串的另一个前缀匹配。
那么上面的式子就无法支持我们完成之后的操作了,所以我们换一种写法。
令
状态转移方程为:
由于我们知道原串,所以整个
那么,由于这道题是矩阵乘法专题里的
因为我们最后只需要第
用矩阵快速幂求出
code:
#include<bits/stdc++.h>
#define fo(x,y,z) for(int (x)=(y);(x)<=(z);(x)++)
#define fu(x,y,z) for(int (x)=(y);(x)>=(z);(x)--)
typedef long long ll;
namespace Aventurine
{
inline int qr()
{
char ch=getchar();int x=0,f=1;
for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
for(;ch>='0'&&ch<='9';ch=getchar())x=(x<<3)+(x<<1)+(ch^48);
return x*f;
}
inline void qw(int x)
{
if(!x)
return;
qw(x/10);
putchar(x%10+'0');
}
inline void qkg(int x)
{
if(x==0)
putchar('0');
else
qw(x);
putchar(' ');
}
inline void qhh(int x)
{
if(x==0)
putchar('0');
else
qw(x);
putchar('\n');
}
}
#define qr qr()
using namespace std;
using namespace Aventurine;
const int Ratio=0;
const int N=55;
const int maxi=INT_MAX;
int n,len,mod,ans;
int kmp[N];
char s[N];
struct rmm
{
int a[N][N];
rmm()
{//一定要初始化!一定要初始化!一定要初始化!
memset(a,0,sizeof a);
}//在结构体中定义的数组需要初始化!
}yns,hdl;
rmm operator*(rmm a,rmm b)//矩阵乘
{
rmm c;
fo(i,0,len-1)
fo(j,0,len-1)
fo(k,0,len-1)
c.a[i][j]=(c.a[i][j]+a.a[i][k]*b.a[k][j]%mod+mod)%mod;
return c;
}
rmm operator^(rmm a,int t)//矩阵快速幂
{
rmm b;
fo(i,0,len-1)
b.a[i][i]=1;
while(t)
{
if(t&1)
b=b*a;
a=a*a;
t>>=1;
}
return b;
}
namespace Wisadel
{
void Wprekmp()//kmp初始化
{
int j=0;
fo(i,2,len)
{
while(j&&s[j+1]!=s[i])
j=kmp[j];
if(s[j+1]==s[i])
j++;
kmp[i]=j;
}
}
void Wwork()
{
fo(i,0,len-1)
for(char ch='0';ch<='9';ch++)
{//枚举添加的字符
int j=i;
while(j&&s[j+1]!=ch)
j=kmp[j];
if(s[j+1]==ch)
j++;
yns.a[i][j]=(yns.a[i][j]+1)%mod;
}
hdl.a[0][0]=1;//即为hdl[0]
yns=yns^n;
hdl=hdl*yns;
fo(i,0,len-1)
ans=(ans+hdl.a[0][i])%mod;
}
short main()
{
n=qr,len=qr,mod=qr;
scanf("%s",s+1);
Wprekmp();
Wwork();
printf("%d\n",ans);
return Ratio;
}
}
int main(){return Wisadel::main();}
完结撒花
我放两张
“维什戴尔”,就把名字签这里,对吧?殿下告诉我,这个名字的意思是“许愿一个家”,但我从不许愿。啊?字太丑?还轮不到你来指指点点。
谁有W的好图啊aa球球了QwQ
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】