BZOJ1030——文本生成器
给你若干给字符串,再给你一个m,问长度是m的字符串中包含给定字符串的数量mod 10007是多少
这个拿过来啥思路也没有,后来还是看了题解,才知道,原来,原来。。。。那个带fail的Trie还可以搞别的
网上的大多数都是26^m-补集做的,麻烦啊,网上有一个非洲猴的blog写的挺好的
设f[i][j][k]表示什么呢,表示i:0..1 j:0..m k:0...size
表示i状态,匹配到j,在Trie上是k的数量
f[i | val[next[c]]][j + 1][next[c]] += f[i][j][k];对就是这样
我已经把next[c] == NULL的都变成fail了,
提醒按照lrj的白书学的AC自动机的同学们,那个last数组在匹配的所有时候都要循环枚举
提醒我自己当k等于0是不是这个位置是无,而是一个未匹配的点,因为计算last和dp时用last耗时代码量费啊
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std;
struct AC{
int ch[100010][30];
int val[100010];
char s[100010];
int f[100010];
int last[100010];
int g[2][200][10010];
int size;
int len;
inline int num(char x){
return x - 'A';
}
inline void init(){
memset(ch, 0, sizeof(ch));
memset(val, 0, sizeof(val));
size = 0;
return;
}
inline void insert(){
int u = 0;
for(int i = 0; i < len; i ++){
int c = num(s[i]);
if(!ch[u][c]){
ch[u][c] = ++ size;
}
u = ch[u][c];
}
val[u] = 1;
return;
}
inline void getfail(){
queue<int> Q;
for(int i = 0; i < 26; i ++) {
if(ch[0][i]) {
Q.push(ch[0][i]);
}
}
while(!Q.empty()){
int r = Q.front(); Q.pop();
for(int i = 0; i < 26; i ++){
int u = ch[r][i];
if(!u){
ch[r][i] = ch[f[r]][i];
continue;
}
Q.push(u);
int v = f[r];
while(v && !ch[v][i]) v = f[v];
f[u] = ch[v][i];
}
}
return;
}
inline int dp(int m){
for(int i = 0; i <= size; i ++){
if(!val[i]){
int j = f[i];
while(j){
if(val[j] == 1){
val[i] = 1;
break;
}
j = f[j];
}
}
}
g[0][0][0] = 1;
for(int i = 0; i <= 1; i ++){
for(int j = 0; j < m; j ++){
for(int k = 0; k <= size; k ++){
for(int c = 0; c < 26; c ++){
g[i | val[ch[k][c]]][j + 1][ch[k][c]] += g[i][j][k];
g[i | val[ch[k][c]]][j + 1][ch[k][c]] %= 10007;
}
}
}
}
int ret = 0;
for(int k = 0; k <= size; k ++) {
ret += g[1][m][k];
ret %= 10007;
}
return ret;
}
} wt;
int main(){
int N, M;
scanf("%d%d", &N, &M);
wt.init();
for(int i = 1; i <= N; i ++){
scanf("%s", wt.s);
wt.len = strlen(wt.s);
//if(wt.len > M) continue;
wt.insert();
}
wt.getfail();
printf("%d\n", wt.dp(M));
return 0;
}
BZOJ1030——文本生成器的更多相关文章
- bzoj1030 文本生成器(AC自动机+dp)
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 4777 Solved: 1986[Submit][Stat ...
- bzoj1030 文本生成器
题目链接 题意 给出\(n\)个字符串,要构造一个长度为\(m\)的字符串\(S\),使得给出的\(n\)个字符串中至少有一个是\(S\)的子串.问方案数. 思路 \(AC\)自动机+\(DP\) 考 ...
- 【BZOJ1030】文本生成器(AC自动机,动态规划)
[BZOJ1030]文本生成器(AC自动机,动态规划) 题面 BZOJ 题解 超级简单良心送分题 很明显是所有状态-不合法状态 合法状态就是\(26^m\) 不合法状态做一个\(dp\)就好 #inc ...
- 【BZOJ1030】[JSOI2007]文本生成器 AC自动机+动态规划
[BZOJ1030][JSOI2007]文本生成器 Description JSOI交给队员ZYX一个任务,编制一个称之为“文本生成器”的电脑软件:该软件的使用者是一些低幼人群,他们现在使用的是GW文 ...
- BZOJ1030 JSOI2007 文本生成器 【AC自动机】【DP】*
BZOJ1030 JSOI2007 文本生成器 Description JSOI交给队员ZYX一个任务,编制一个称之为"文本生成器"的电脑软件:该软件的使用者是一些低幼人群,他们现 ...
- 【bzoj1030】: [JSOI2007]文本生成器 字符串-AC自动机-DP
[bzoj1030]: [JSOI2007]文本生成器 首先把匹配任意一个的个数的问题转化为总个数-没有一个匹配的个数 先构造AC自动机,然后枚举每一位的字母以及在自动机上的位置 f[i][j]为第i ...
- 【BZOJ-1030】文本生成器 AC自动机 + DP
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 3253 Solved: 1330[Submit][Stat ...
- bzoj1030 [JSOI2007]文本生成器
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2654 Solved: 1100[Submit][Stat ...
- C++之路进阶——bzoj1030(文本生成器)
F.A.Qs Home Discuss ProblemSet Status Ranklist Contest ModifyUser hyxzc Logout 捐赠本站 Notice:由于本OJ建立在 ...
随机推荐
- xbmc的静态链接办法
XBMC是一个相当酷的音频/视频播放器,号称家庭影视中心. 我是希望静态将一些库链接进可执行程序的,这样我用的ArchLinux就不用天天在更新一些东西了 但XBMC试了很多次,编译成功后,总是在运行 ...
- electron-Node.js Error: Module version mismatch. Expected
本来以为是nodejs的版本问题,后来才发现是electron用本地包的问题 Installing modules and rebuilding for Electron You can also c ...
- centos nc命令安装
yum install nc.x86_64 nc命令的参数 参数 作用-i 设置数据报传送时间间隔-l 以服务器方式运行-k 重复接收并处理某个端口上的所有连接,必须与-l选项一起使用-n 使用ip地 ...
- 用arp-scan扫描局域网IP地址
1,在安装之前需要安装yum install -y libpcap libpcap-devel如果没有安装yum工具需要用rpm安装如下软件包[root@oradba arp-scan-1.8]# y ...
- JavaWeb学习笔记——JavaBean的保存范围和删除
- CodeForces - 699B One Bomb
题目地址:http://codeforces.com/contest/699/problem/B 题目大意: 一个矩阵,内容由‘.’和‘*’组成(‘.’ 空,‘*’ 代表墙),墙分布在不同位置,现找出 ...
- Autofac.Integration.Web分析
using System; using System.Web; using Autofac.Core.Lifetime; namespace Autofac.Integration.Web { /// ...
- Java中关于HashMap的元素遍历的顺序问题
Java中关于HashMap的元素遍历的顺序问题 今天在使用如下的方式遍历HashMap里面的元素时 1 for (Entry<String, String> entry : hashMa ...
- javascript生成二维码
参考: http://www.w3dev.cn/article/20140617/javascript-create-QR-code.aspx
- 浅谈JavaScript中的Function引用类型
引言 在JavaScript中最有意思的就是函数了,这一切的根源在于函数实际上是一个对象.每一个函数都是Function类型的实例,而且都和其他引用类型的实例一样具有属性和方法.函数作为一个对象,因此 ...