http://www.lydsy.com/JudgeOnline/problem.php?id=1030 (题目链接)

题意

  给出$n$个单词,问有多少个长度为$m$的文本中至少包含一个单词。

Solution

  构造好AC自动机以后在上面dp,$f[i][j]$表示长度为$i$匹配到自动机上节点$j$时的没有被任意单词匹配的文本个数。转移枚举接在第$j+1$个位置的字符是哪一个,并且保证走过的节点没有一个是结束节点就可以了。

细节

  0号节点为root。

代码

// bzoj1030
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
#define LL long long
#define inf (1ll<<30)
#define MOD 10007
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout)
using namespace std; const int maxl=200,maxn=60;
int n,m,sz=1,f[maxl][maxn*maxl];
char s[maxl];
struct node {
int son[26],next,end;
int& operator [] (int x) {return son[x];}
}tr[maxn*maxl]; namespace ACM {
void insert(char *r) {
int len=strlen(r+1),p=1;
for (int i=1;i<=len;i++) {
if (!tr[p][r[i]-'A']) tr[p][r[i]-'A']=++sz;
p=tr[p][r[i]-'A'];
}
tr[p].end=1;
}
void buildfail() {
queue<int> q;q.push(1);
tr[1].next=0;
while (!q.empty()) {
int x=q.front();q.pop();
for (int i=0;i<26;i++) if (tr[x][i]) {
int k=tr[x].next;
while (!tr[k][i]) k=tr[k].next;
tr[tr[x][i]].next=tr[k][i];
tr[tr[x][i]].end|=tr[tr[k][i]].end;
q.push(tr[x][i]);
}
}
}
}
using namespace ACM; int main() {
scanf("%d%d",&n,&m);
for (int i=0;i<26;i++) tr[0][i]=1;
for (int i=1;i<=n;i++) {
scanf("%s",s+1);
insert(s);
}
buildfail();
f[0][1]=1;
for (int i=0;i<m;i++)
for (int j=1;j<=sz;j++) if (f[i][j]) {
for (int k=0;k<26;k++) {
int p=j;
while (!tr[p][k]) p=tr[p].next;
p=tr[p][k];
if (!tr[p].end) (f[i+1][p]+=f[i][j])%=MOD;
}
}
int sum=1,ans=0;
for (int i=1;i<=m;i++) (sum*=26)%=MOD;
for (int i=1;i<=sz;i++) (ans+=f[m][i])%=MOD;
printf("%d\n",(sum-ans+MOD)%MOD);
return 0;
}

最新文章

  1. 时代杂志发文:2017 AR/MR将变得比VR更加重要
  2. [Linux-shell] AWK
  3. jquery 获取input radio/checkbox 的值 【注意写法】
  4. oracle linux 下卸载
  5. Mybatis3+Spring4+SpringMVC4 整合
  6. Codeforces Round #261 (Div. 2)
  7. UVa 1395 Slim Span【最小生成树】
  8. 简易nagios安装出现的问题及解决方法
  9. iOS开发之数据存取2-CoreData后台查询数据
  10. JMeter Ultimate Thread Group阶梯式减压
  11. sqflite插件简单使用 key======================
  12. Ansible 安装与配置(一)
  13. UnicodeEncodeError: &#39;ascii&#39; codec can&#39;t encode characters in position
  14. CentOS 7.0下使用yum安装MySQL
  15. 在datasnap 中使用unidac 访问数据(服务器端)
  16. Anaconda2和Anaconda3同时安装
  17. elemet-paging
  18. Hyperledger fabric 1.3版本的安装部署(原创多机多Orderer部署
  19. T-SQL 局部变量和全局变量
  20. 神经网络前向后向传播(理论推导+代码) 单层神经网络相当于logistic regression

热门文章

  1. 大数据入门第二十三天——SparkSQL(二)结合hive
  2. 2017-2018 Exp7 网络欺诈技术防范 20155214
  3. 20155234 Exp2 后门原理与实践
  4. ListBox项模板中绑定ListBoxItem属性的方法
  5. mfc 进程的优先级
  6. CS50.3
  7. MOSFET中的重要参数
  8. Android Studio发布Release版本之坑--Unknown host &#39;d29vzk4ow07wi7.cloudfront.net&#39;
  9. Final阶段用户使用报告
  10. M1事后总结报告