2781: [JSOI2007]文本生成器
2781: [JSOI2007]文本生成器
Time Limit: 1 Sec Memory Limit: 128 MB
Submit: 8 Solved: 4
[Submit][Status][Web Board]
Description
Input
Output
Sample Input
2 2
A
B
Sample Output
100
HINT
Source
题解:
第一眼,Ac自动机。然后。。。。。。就JJ了,不知道怎么写了(QAQ)
然后YY了半天总算有点点想法:我们直接计算的话,还真心有点小困难,所以怎么写呢?(龙老师:这,乱搞出奇迹,电脑砸了就好了!!!)
额。。。。。。
好吧,我们就算一下不可读的串数,总串数减去它就可以了。。。。。(龙老师:写什么写,乱搞出奇迹,War3飞起!!!)
不可读的串的数量就是在AC自动机上走M步而不经过结尾节点(包括结尾点和fail指向结尾点的节点)的路径条数。
这个怎么求呢?
设f[i][j]表示走i步,现在在j号节点的路径条数。
那么f[i][j]可以转移f[i+1][son[j][k]]。
就是i+1个字符为k的状态。
最后把所有f[m][i]累和就是不可读的串。(龙老师:说了吧,乱搞就写出来啦,还是我最吊!!!!)
#include<cstdio>
#include<cstring>
#include<algorithm>
const int maxn=,maxm=,mod=;
using namespace std;
int n,m,f[maxm][maxn],ans1=,ans2; char s[maxn]; int tot,son[maxn][],fail[maxn],q[maxn],head,tail;bool dang[maxn];
void insert(){
int p=,len=strlen(s);
for (int i=;i<len;p=son[p][s[i]-'A'],i++) if (!son[p][s[i]-'A']) son[p][s[i]-'A']=++tot;
dang[p]=;
}
void getfail(){
head=,q[tail=]=,fail[]=-;
while (head!=tail){
int x=q[++head];
for (int i=;i<;i++)
if (son[x][i]) q[++tail]=son[x][i],fail[son[x][i]]=x==?:son[fail[x]][i];
else son[x][i]=x==?:son[fail[x]][i];
dang[x]|=dang[fail[x]];
}
}
void work(){
f[][]=;
for (int i=;i<=m;i++)
for (int j=;j<=tot;j++){
if (dang[j]) continue;
for (int k=;k<;k++)
f[i][son[j][k]]=(f[i][son[j][k]]+f[i-][j])%mod;
}
for (int i=;i<=tot;i++) if (!dang[i]) ans2+=f[m][i];
for (int i=;i<=m;i++) ans1=(ans1*)%mod;
printf("%d\n",((ans1-ans2)%mod+mod)%mod);
} int main(){
scanf("%d%d",&n,&m);
for (int i=;i<=n;i++) scanf("%s",s),insert();
getfail(),work();
return ;
}
2781: [JSOI2007]文本生成器的更多相关文章
- BZOJ 1030: [JSOI2007]文本生成器 [AC自动机 DP]
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 3953 Solved: 1614[Submit][Stat ...
- bzoj1030 [JSOI2007]文本生成器
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2654 Solved: 1100[Submit][Stat ...
- JSOI2007文本生成器
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 1613 Solved: 656[Submit][Statu ...
- BZOJ 1030 [JSOI2007]文本生成器
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2624 Solved: 1087[Submit][Stat ...
- BZOJ_1030_[JSOI2007]文本生成器_AC自动机+DP
BZOJ_1030_[JSOI2007]文本生成器_AC自动机+DP Description JSOI交给队员ZYX一个任务,编制一个称之为“文本生成器”的电脑软件:该软件的使用者是一些低幼人群, 他 ...
- P4052 [JSOI2007]文本生成器
P4052 [JSOI2007]文本生成器 AC自动机+dp 优秀题解传送门 设f[ i ][ j ]表示串的长度为 i ,当前在 j 点时不可识别的串的方案数 最后用总方案数减去不可识别方案数就是答 ...
- 【BZOJ1030】[JSOI2007]文本生成器 AC自动机+动态规划
[BZOJ1030][JSOI2007]文本生成器 Description JSOI交给队员ZYX一个任务,编制一个称之为“文本生成器”的电脑软件:该软件的使用者是一些低幼人群,他们现在使用的是GW文 ...
- [JSOI2007]文本生成器 --- AC自动机 + DP
[JSOI2007]文本生成器 题目描述: JSOI交给队员ZYX一个任务,编制一个称之为“文本生成器”的电脑软件:该软件的使用者是一些低幼人群,他们现在使用的是GW文本生成器v6版. 该软件可以随机 ...
- BZOJ1030 JSOI2007 文本生成器 【AC自动机】【DP】*
BZOJ1030 JSOI2007 文本生成器 Description JSOI交给队员ZYX一个任务,编制一个称之为"文本生成器"的电脑软件:该软件的使用者是一些低幼人群,他们现 ...
随机推荐
- .NET中公共变量与属性的区别
在我们的程序中经常会出现以下的代码: 如: 成员变量 public string Name; 或者用属性 private string name ...
- 转 android学习—— context 和 getApplicationContext()
在android中常常会遇到与context有关的内容 浅论一下context : 在语句 AlertDialog.Builder builder = new AlertDialog.Builder( ...
- Brain Network (medium)
Brain Network (medium) Further research on zombie thought processes yielded interesting results. As ...
- 分析UIWindow
转载自:http://www.cnblogs.com/YouXianMing/p/3811741.html The UIWindow class defines an object known as ...
- fragment 数据传递,传值,通信
[原][Fragment精深系列4]Fragment与Activity之间的数据交互 2015-5-26阅读389 评论0 以下内容来自于自己的实践和网络资料的整理,希望对你有帮助. 一.Acti ...
- vs2005中分割线怎么插入
用Label控件,将Label控件的AutoSize设为False,然后清除Text属性,再将BorderStyle属性设为Fixed3D,宽度设为2个像素,就可以成为分割线. 效果:
- Bootstrap 手风琴搭配导航条实现常用菜单栏
效果 HTML代码 <div class="sidebar"> <div class="mc-search"> <div clas ...
- Struts2--带参数的结果集
带参数的结果集: 配置文件: <result type="redirect">/user_success.jsp?t=${type}</result> js ...
- Bluez SPP实现代码分析(转)
源:http://blog.csdn.net/walkingman321/article/details/7218705 本文分析蓝牙协议栈中蓝牙转串口(SPP)部分的实现. 1. 基本概念 Blu ...
- Fruit Feast
Fruit Feast 题目描述 Bessie has broken into Farmer John's house again! She has discovered a pile of lemo ...