Censored! - POJ 1625(ac自动机+简单dp+高精度运算)
#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<string.h>
#include<queue>
using namespace std; const int MAXN = ;
const int oo = 1e9+; char WordList[MAXN];
int MaxSon, Matrix[MAXN][MAXN]; struct Ac_Trie
{
int next[MAXN][MAXN], size;
int Fail[MAXN], End[MAXN], root; int newnode()
{
memset(next[size], -, sizeof(next[size]));
Fail[size] = End[size] = false; return size++;
}
void InIt()
{
size = ;
root = newnode();
} void Insert(char s[])
{
int now = root; for(int i=; s[i]; i++)
{
int k = strchr(WordList, s[i]) - WordList; if(next[now][k] == -)
next[now][k] = newnode();
now = next[now][k];
} End[now] = true;
} void GetFail()
{
queue<int> Q;
int now = root; Fail[root] = root; for(int i=; i<MaxSon; i++)
{
if(next[now][i] == -)
next[now][i] = root;
else
{
Fail[next[now][i]] = root;
Q.push(next[now][i]);
}
} while(Q.size())
{
now = Q.front();
Q.pop(); for(int i=; i<MaxSon; i++)
{
if(next[now][i] == -)
next[now][i] = next[Fail[now]][i];
else
{
Fail[next[now][i]] = next[Fail[now]][i];
Q.push(next[now][i]);
}
} End[now] |= End[Fail[now]];
}
}
void GetMatrix()
{
memset(Matrix, false, sizeof(Matrix)); for(int i=; i<size; i++)
for(int k=; k<MaxSon; k++)
{
if(!End[next[i][k]] && !End[i])
Matrix[i][next[i][k]] += ;
}
}
};
Ac_Trie ac; void BigNumAdd(int a[], int num, int b[])
{
for(int i=; i<MAXN; i++)
b[i] += a[i] * num; for(int i=; i<MAXN-; i++)
{
b[i+] += b[i] / ;
b[i] %= ;
}
} int main()
{
int N, P; while(scanf("%d%d%d", &MaxSon, &N, &P) != EOF)
{
char s[MAXN];
ac.InIt(); getchar();
gets(WordList); while(P--)
{
gets(s);
ac.Insert(s);
} ac.GetFail();
ac.GetMatrix(); int dp[][MAXN][MAXN] = {}, op=;
dp[][][] = ;
while(N--)
{
memset(dp[op], false, sizeof(dp[op])); for(int i=; i<ac.size; i++)
for(int j=; j<ac.size; j++)
{
if(Matrix[i][j])
{///dp[op][j] += dp[op^1][i] * Matrix[i][j];
BigNumAdd(dp[op^][i], Matrix[i][j], dp[op][j]);
}
} op ^= ;
} int ans[MAXN] = {}; for(int i=; i<ac.size; i++)
BigNumAdd(dp[op^][i], , ans); N = MAXN - ;
while(ans[N] == && N > )
N--; for(int i=N; i>=; i--)
printf("%d", ans[i]);
printf("\n");
} return ;
}
Censored! - POJ 1625(ac自动机+简单dp+高精度运算)的更多相关文章
- Censored! POJ - 1625 AC自动机+大数DP
题意: 给出一n种字符的字典,有p个禁用的单词, 问能组成多少个不同的长度为m的合法字符串.(m<=50) 题解: 是不是个我们之前做的题目非常非常像,题意都一样. 直接将上次写的AC自动机+矩 ...
- Ring HDU - 2296 AC自动机+简单DP和恶心的方案输出
题意: 就是现在给出m个串,每个串都有一个权值,现在你要找到一个长度不超过n的字符串, 其中之前的m个串每出现一次就算一次那个字符串的权值, 求能找到的最大权值的字符串,如果存在多个解,输出最短的字典 ...
- 小明系列故事――女友的考验 HDU - 4511 AC自动机+简单DP
题意:自己看题目,中文体面. 题解: 把所有不能走的路径放入AC自动机中. 然后DP[i][j]表示走到 i 这个点,且位于AC自动机 j 这个节点最短距离 然后直接DP即可.注意一点会爆int #i ...
- 【HDU3530】 [Sdoi2014]数数 (AC自动机+数位DP)
3530: [Sdoi2014]数数 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 682 Solved: 364 Description 我们称一 ...
- 关于AC自动机和DP的联系
首先是描述个大概.不说一些特殊的DP 或者借用矩阵来状态转移 (这些本质都是一样的). 只讲AC自动机和DP的关系(个人理解). AC自动机 又可以叫做状态机. 我一开始的认为.AC 自动机提供了一些 ...
- 【bzoj3530】[Sdoi2014]数数 AC自动机+数位dp
题目描述 我们称一个正整数N是幸运数,当且仅当它的十进制表示中不包含数字串集合S中任意一个元素作为其子串.例如当S=(22,333,0233)时,233是幸运数,2333.20233.3223不是幸运 ...
- BZOJ 3530 [SDOI2014]数数 (Trie图/AC自动机+数位DP)
题目大意:略 裸的AC自动机+数位DP吧... 定义f[i][x][0/1]表示已经匹配到了第i位,当前位置是x,0表示没到上限,1到上限,此时数是数量 然而会出现虚拟前导零,即前几位没有数字的情况, ...
- POJ 3691 (AC自动机+状态压缩DP)
题目链接: http://poj.org/problem?id=3691 题目大意:给定N个致病DNA片段以及一个最终DNA片段.问最终DNA片段最少修改多少个字符,使得不包含任一致病DNA. 解题 ...
- Walk Through Squares HDU - 4758 AC自动机+简单状压DP
题意:给你两个串,求用m个R,n个D能组成多少个包含这两个串 题解:先构造一个AC自动机记录每个状态包含两个串的状态, 状态很容易定义 dp[i][j][k][status]表示在AC自动机K这个节点 ...
随机推荐
- C#中Dictionary、ArrayList、Hashtable和Array的区别
IDictionary接口是所有字典类集合的基本接口,该接口与ICollection,IEnumerable接口是所有非泛型类集合的最基本的接口 IEnumerable接口用于公开枚举数,该枚举数支持 ...
- openwrt advanced configuration
openwrt高级配置(汗 照着标题就翻译过来了) openwrt Kamikaze 8.09的一般配置文件都在目录 /etc/config 下面,可以使用脚本来调用参数和设置参数. 比如 sbin/ ...
- Python:函数定义
#!/usr/bin/python3 #函数 def add(a,b): return a+b print("add(2,5) = ",add(2,5)) def add2(a,b ...
- Cocos Studio1.5.0.1开发学习笔记(一)
听说Cocos Studio很久了,主要是因为骨骼动画.目前看来Cocos2d-x播放动画的方式只有2种: 第一种:是播放序列帧动画,即将动画的每一帧都加载进缓存里,需要播放时再使用Animation ...
- linux搜索命令
1. find find是最常见和最强大的查找命令,你可以用它找到任何你想找的文件. find的使用格式如下: $ find <指定目录> <指定条件> <指定动作> ...
- 15_RHEL7挂载NTFS分区
1.下载ntfs-3g wget https://tuxera.com/opensource/ntfs-3g_ntfsprogs-2015.3.14.tgz 2.安装 tar -zxvf ntfs-3 ...
- 矩形嵌套问题-ACM集训
参考 http://blog.csdn.net/xujinsmile/article/details/7861412 有n个矩形,每个矩形可以用a,b来描述,表示长和宽.矩形X(a,b)可以嵌套在矩形 ...
- <和>
今天用到>查了查资料就是这么个回事.
- VS2010与VAssistX
http://www.cnblogs.com/9tian/archive/2011/07/01/2095202.html 最近越来越觉得VAssistX好用,可能是以前没有去仔细研究过吧,也可能是因为 ...
- Notepad++ Shortcuts(Chinese and English Version)
Ctrl+C 复制Ctrl+X 剪切Ctrl+V 粘贴Ctrl+Z 撤消Ctrl+Y 恢复Ctrl+A 全选Ctrl+F 键查找对话框启动Ctrl+H 查找/替换对话框Ctrl+D 复制并粘贴当行 C ...