BZOJ 1009 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位的数。 100%数据N<=10^9,M<=20,K<=1000 40%数据N<=1000 10%数据N<=6
Output
阿申想知道不出现不吉利数字的号码有多少种,输出模K取余的结果.
Sample Input
111
Sample Output
HINT
Source
利用“不吉利数字”构建ac自动机(我好像小题大做了,一个串好像没有必要),构建初始矩阵,接着矩阵乘法即可。
初始矩阵a[i][j]表示走一步从i节点走到j节点的方案数。
code:
#include<vector>
#include<queue>
#include<cstring>
#include<cstdio>
#include<cstdlib>
using namespace std; #define maxm 25
char buf[maxm];
int n,m,rhl,ans; struct node
{
int a[maxm*maxm][maxm*maxm],n,m;
node() {memset(a,,sizeof(a));n = m = ;} friend node operator *(node x,node y)
{
node z; z.n = x.n; z.m = y.m;
int i,j,k;
for (i = ;i <= z.n;++i)
for (j = ;j <= z.m;++j)
for (k = ;k <= x.m;++k)
(z.a[i][j] += (long long)x.a[i][k]*(long long)y.a[k][j]%rhl)%=rhl;
return z;
} inline node quick(node x,int k)
{
node ret; ret.n = x.n; ret.m = x.m;
for (int i = ;i <= ret.n;++i) ret.a[i][i] = ;
for (;k;k>>=,x = x*x)
if (k & )
ret = ret*x;
return ret;
} inline void calc() { for (int i = ;i <= m;++i) (ans += a[][i])%=rhl; }
}s; struct trie
{
int next[maxm][],fail[maxm],L,root;
bool end[maxm];
inline int newnode()
{
memset(next[L],-,sizeof(next[L]));
return ++L-;
} inline void init() {L = ; root = newnode();} inline void insert()
{
int len = strlen(buf),now = root,i;
for (i = ;i < len;++i)
{
if (next[now][buf[i]-''] == -) next[now][buf[i]-''] = newnode();
now = next[now][buf[i]-''];
}
end[now] = true;
} inline void build()
{
int now = root,i; queue <int> team;
fail[root] = root;
for (i = ;i < ;++i)
if (next[now][i] == -) next[now][i] = root;
else fail[next[now][i]] = root,team.push(next[now][i]);
while (!team.empty())
{
now = team.front(); team.pop();
for (i = ;i < ;++i)
if (next[now][i] == -) next[now][i] = next[fail[now]][i];
else fail[next[now][i]] = next[fail[now]][i],team.push(next[now][i]);
}
} inline void ready()
{
vector <int> son[maxm]; queue <int> team; int i,now,v,nn;
for (i = ;i < L;++i) if (fail[i] != i) son[fail[i]].push_back(i);
team.push(root);
while (!team.empty())
{
now = team.front(); team.pop();
nn = son[now].size();
for (i = ;i < nn;++i)
{
v = son[now][i];
if (end[now]) end[v] = true;
team.push(v);
}
}
} inline void make()
{
int i,j; s.n = s.m = L;
for (i = ;i < L;++i)
{
if (end[i]) continue;
for (j = ;j < ;++j)
if (!end[next[i][j]]) s.a[i+][next[i][j]+]++;
}
}
}ac; int main()
{
freopen("1009.in","r",stdin);
freopen("1009.out","w",stdout);
scanf("%d %d %d\n",&n,&m,&rhl);
ac.init();
scanf("%s",buf); ac.insert();
ac.build(); ac.ready(); ac.make();
s = s.quick(s,n); s.calc();
printf("%d",ans);
fclose(stdin); fclose(stdout);
return ;
}
BZOJ 1009 GT考试的更多相关文章
- BZOJ 1009 GT考试(ac自动机+矩阵DP)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1009 题意:给定一个长度为m的串s.有多少种长度为n的串不包含s? 思路:(1)将s插入 ...
- BZOJ 1009 GT考试 (AC自动机 + 矩阵乘法加速dp)
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1009 题意: 准考证号为\(n\)位数\(X_1X_2....X_n(0<=X_ ...
- bzoj 做起走 -- bzoj 1009 GT 考试
现在每次做一道bzoj上的题,整个人都感觉升华了... 先是在网上各种搜题解.要么只有代码,要么有点讲解看不懂,对于从来没有耐心看完别人代码的我,只能一篇一篇的翻..然后终于在某2011级同学的某段话 ...
- [BZOJ 1009] [HNOI2008] GT考试 【AC自动机 + 矩阵乘法优化DP】
题目链接:BZOJ - 1009 题目分析 题目要求求出不包含给定字符串的长度为 n 的字符串的数量. 既然这样,应该就是 KMP + DP ,用 f[i][j] 表示长度为 i ,匹配到模式串第 j ...
- BZOJ 1009: [HNOI2008]GT考试( dp + 矩阵快速幂 + kmp )
写了一个早上...就因为把长度为m的也算进去了... dp(i, j)表示准考证号前i个字符匹配了不吉利数字前j个的方案数. kmp预处理, 然后对于j进行枚举, 对数字0~9也枚举算出f(i, j) ...
- BZOJ 1009 HNOI 2008 GT考试 递推+矩乘
1009: [HNOI2008]GT考试 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 3679 Solved: 2254[Submit][Statu ...
- BZOJ 1009 [HNOI2008]GT考试 (KMP + 矩阵快速幂)
1009: [HNOI2008]GT考试 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 4266 Solved: 2616[Submit][Statu ...
- bzoj 1009: [HNOI2008]GT考试 -- KMP+矩阵
1009: [HNOI2008]GT考试 Time Limit: 1 Sec Memory Limit: 162 MB Description 阿申准备报名参加GT考试,准考证号为N位数X1X2.. ...
- GT考试(bzoj 1009)
Description 阿申准备报名参加GT考试,准考证号为N位数X1X2....Xn(0<=Xi<=9),他不希望准考证号上出现不吉利的数字.他的不吉利数学A1A2...Am(0< ...
随机推荐
- js 中cookie 使用
一个系统有多种 角色, 每一种角色不同权限.后台请求的数据根据权限展示 ,所以要把权限保存在浏览器中. 首先 引入 在页面 <script type="text/javascript& ...
- div页面居中(上下左右)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.or ...
- linux安装总结(亲测)
一:磁盘分区情况 NTFS,FAT32 这是两种常用的磁盘格式 windows7自带的磁盘工具也可以分出上面的格式,用软件也可以.但是FAT32最大的复制文件进去的限度时4G. EXT3只能用软件才能 ...
- Writing Your First Test
Let's say you have an activity layout that represents a welcome screen: <?xml version="1.0&q ...
- NUll在oracle与sqlserver中使用相同与区别
最近在使用Oracle进行开发,遇到很多与以前使用sqlserver的不同语法.今天遇到null在两种数据库上面操作上的差别,在此记录两种数据库上的差异. null 与字符串相加 1.在oracle中 ...
- Unity3D 5.0简单的射线检测实现跳跃功能
这里是一个简单的跳跃,5.0和其他版本貌似不一样,并且,再起跳功能做的不完全. 不过一个基本的思路在这里. 1.首先,射线检测,这里是利用一个空对象,放到主角对象的下面 2.然后调节射线的位置,在主角 ...
- PHP替换数据库的换行符
//php 有三种方法来解决 //1.使用str_replace 来替换换行 $str = str_replace(array("\r\n", "\r", &q ...
- 访问nginx提示gateway timeout 504 ,发现总是当调用时间超过30s时提示504错误
解决办法: 需要修改php-fpm的配置文件 request_terminate_timeout=30s 参考文档: http://baike.baidu.com/view/641394.htm ht ...
- [转载]CentOS6.4+Mono3.0.7+Jexus5.2.5
本文章来自互联网,但是本人已经在VM虚拟机里面测试成功,所以分享给大家 1.更新 yum -y update 2.安装Mono源码安装需要的库 yum -y install gcc gcc-c++ a ...
- for循环,如何结束多层for循环
采用标签方式跳出,指定跳出位置, a:for(int i=0;i<n;i++) { b:for(int j=0;j<n;j++) { if(n=0) { break a; } } }