【BZOJ1009】[HNOI2008]GT考试 next数组+矩阵乘法
【BZOJ1009】[HNOI2008]GT考试
Description
  阿申准备报名参加GT考试,准考证号为N位数X1X2....Xn(0<=Xi<=9),他不希望准考证号上出现不吉利的数字。
他的不吉利数学A1A2...Am(0<=Ai<=9)有M位,不出现是指X1X2...Xn中没有恰好一段等于A1A2...Am. A1和X1可以为
0
Input
第一行输入N,M,K.接下来一行输入M位的数。 N<=10^9,M<=20,K<=1000
Output
阿申想知道不出现不吉利数字的号码有多少种,输出模K取余的结果.
Sample Input
111
Sample Output
题解:虽然AC自动机的fail和KMP的next只差了那么一点点,但为什么感觉AC自动机比KMP好理解100倍~
好吧我们还是用KMP,先求出next数组,然后用f[i][j]表示i位数,第i位数匹配到了模板串的第j位时的方案数
然后从0..9枚举第i+1位,设加入了第i+1位后匹配到了位置k,则有f[i+1][k]+=f[i][j]
若第i位正好匹配成功,此时k=m,则f[i+1][m]+=f[i][j]
显然我们可以用矩乘来优化这个DP过程,我们令x[i][j]表示经过1次匹配后,从位置i匹配到了位置j的方案数。那么对于上面所有符合条件的(j,k),我们都令x[j][k]=1,初始ans[0][0]=1。然后ans*=x^N,答案就是∑ans[0][0...m-1]
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
int next[25];
char str[25];
typedef struct matrix
{
int v[25][25];
}M;
M x,ans,emp;
int n,m,mod,sum;
M mmul(M a,M b)
{
M c=emp;
int i,j,k;
for(i=0;i<=m;i++)
for(j=0;j<=m;j++)
for(k=0;k<=m;k++)
c.v[i][j]=(c.v[i][j]+a.v[i][k]*b.v[k][j])%mod;
return c;
}
void pm(int y)
{
while(y)
{
if(y&1) ans=mmul(ans,x);
x=mmul(x,x),y>>=1;
}
}
int main()
{
scanf("%d%d%d%s",&n,&m,&mod,str);
int i=0,j=-1,k;
next[0]=-1;
while(i<m-1)
{
if(j==-1||str[i]==str[j]) next[++i]=++j;
else j=next[j];
}
for(i=0;i<m;i++)
{
for(j=0;j<=9;j++)
{
k=i;
while(k!=-1&&str[k]-'0'!=j) k=next[k];
x.v[i][k+1]++;
}
}
x.v[m][m]=10,ans.v[0][0]=1;
pm(n);
for(i=0;i<m;i++) sum=(sum+ans.v[0][i])%mod;
printf("%d",sum);
return 0;
}
【BZOJ1009】[HNOI2008]GT考试 next数组+矩阵乘法的更多相关文章
- bzoj1009: [HNOI2008]GT考试(kmp+矩阵乘法)
		
1009: [HNOI2008]GT考试 题目:传送门 题解: 看这第一眼是不是瞬间想起组合数学??? 没错...这样想你就GG了! 其实这是一道稍有隐藏的矩阵乘法,好题! 首先我们可以简化一下题意: ...
 - [BZOJ1009] [HNOI2008] GT考试 (KMP & dp & 矩阵乘法)
		
Description 阿申准备报名参加GT考试,准考证号为N位数X1X2....Xn(0<=Xi<=9),他不希望准考证号上出现不吉利的数字. 他的不吉利数学A1A2...Am(0< ...
 - [BZOJ1009] [HNOI2008] GT考试(KMP+dp+矩阵快速幂)
		
[BZOJ1009] [HNOI2008] GT考试(KMP+dp+矩阵快速幂) 题面 阿申准备报名参加GT考试,准考证号为N位数X1X2-.Xn,他不希望准考证号上出现不吉利的数字.他的不吉利数学A ...
 - 【BZOJ-1009】GT考试      KMP+DP+矩阵乘法+快速幂
		
1009: [HNOI2008]GT考试 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2745 Solved: 1694[Submit][Statu ...
 - 【BZOJ】1009: [HNOI2008]GT考试(dp+矩阵乘法+kmp+神题)
		
http://www.lydsy.com/JudgeOnline/problem.php?id=1009 好神的题orzzzzzzzzzz 首先我是连递推方程都想不出的人...一直想用组合来搞..看来 ...
 - BZOJ 1009 HNOI2008 GT考试 KMP算法+矩阵乘法
		
标题效果:给定的长度m数字字符串s.求不包括子s长度n数字串的数目 n<=10^9 看这个O(n)它与 我们不认为这 令f[i][j]长度i号码的最后的字符串j位和s前者j数字匹配方案 例如,当 ...
 - HNOI2008 GT考试 (KMP + 矩阵乘法)
		
传送门 这道题目的题意描述,通俗一点说就是这样:有一个长度为n的数字串(其中每一位都可以是0到9之间任意一个数字),给定一个长度为m的模式串,求有多少种情况,使得此模式串不为数字串的任意一个子串.结果 ...
 - P3193 [HNOI2008]GT考试(KMP+矩阵乘法加速dp)
		
P3193 [HNOI2008]GT考试 思路: 设\(dp(i,j)\)为\(N\)位数从高到低第\(i\)位时,不吉利数字在第\(j\)位时的情况总数,那么转移方程就为: \[dp(i,j)=dp ...
 - 2018.10.22 bzoj1009: [HNOI2008]GT考试(kmp+矩阵快速幂优化dp)
		
传送门 f[i][j]f[i][j]f[i][j]表示从状态"匹配了前i位"转移到"匹配了前j位"的方案数. 这个东西单次是可以通过跳kmp的fail数组得到的 ...
 
随机推荐
- unity, 替换shader渲染(Rendering with Replaced Shaders)
			
实现特效,尤其是一些后处理特效,经常需要将各物体的shader替换为另一套shader进行渲染到纹理,再后再进行合成或以某种叠加方式叠加到最后的画面上去. 再复杂一点儿的,可能不同的物体所用的替换sh ...
 - jqury插件编写
			
sae中短信验证码: ; (function($) { $(document).ready(function() { if (parent && parent.location.hre ...
 - JVM虚拟机(四):JVM 垃圾回收机制概念及其算法
			
垃圾回收概念和其算法 谈到垃圾回收(Garbage Collection)GC,需要先澄清什么是垃圾,类比日常生活中的垃圾,我们会把他们丢入垃圾箱,然后倒掉.GC中的垃圾,特指存于内存中.不会再被使用 ...
 - 关于 initWithNibName 和 loadNibNamed 的区别和联系-iPhone成长之路
			
转自:http://blog.sina.com.cn/s/blog_7b9d64af01018f2u.html 关于 initWithNibName 和 loadNibNamed 的区别和联系.之所以 ...
 - shell判断文件夹是否存在
			
#shell判断文件夹是否存在 #如果文件夹不存在,创建文件夹 if [ ! -d "/myfolder" ]; then mkdir /myfolder fi #shell判断文 ...
 - SAP ECC6安装系列四:安装过程详解
			
原作者博客 http://www.cnblogs.com/Michael_z/ ======================================== 续接上篇,我们终于按下了 “Next” ...
 - 基于HTML5/CSS3可折叠的3D立方体动画
			
今天要给大家带来另外一款CSS3 3D立方体动画,尤其在DEMO2中可以看到,鼠标滑过立方体后,它将会被打开,从里面弹出另外一个小立方体,动画效果非常酷,非常逼真. 在线预览 源码下载 实现的代码 ...
 - Apache Rewrite 拟静态
			
mod_rewrite是Apache的一个非常强大的功能,它可以实现伪静态页面.一些防盗链就是通过该方法做到的. 00x1 启动rewrite引擎 00x2 如何启用apache rewrite? 0 ...
 - Psql 安装问题
			
在openerp安装过程中报错: psql: could not connect to server: No such file or directory Is the server running ...
 - [kernel]如何主动触发一次kernel panic
			
Step1: echo 1 > /proc/sys/kernel/sysrq 或者如果不想每次运行上面的命令,可以echo "kernel.sysrq=1" >> ...