【uva11468-Substring】AC自动机+dp
http://acm.hust.edu.cn/vjudge/problem/31655
题意:给定k个模板串,n个字符以及选择它的概率pro[i],要构造一个长度问L的字符串s,问s不包含任意一个模板串的概率。
题解:
ed[i]标记trie上的点i是不是任意一个模板串的结尾(在求fail的时候ed[i]|=ed[i.fail])
d[i][l]表示从i出发还要走l步,构造的串不含模板串的概率,dp一下。注意清零。
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<queue>
using namespace std; const int N=,L=,S=;
char s[L];
int cnt[N*L];
double d[N*L][L],pro[];
bool ed[N*L];
queue<int> q;
int num,k,n,l;
struct node{
int son[];
int fail;
}a[N*L]; int idx(char c)
{
if(c<='z' && c>='a') return c-'a'+;
if(c<='Z' && c>='A') return c-'A'+;
return c-''+;
} void clear(int x)
{
a[x].fail=;
memset(a[x].son,,sizeof(a[x].son));
} void trie(char *c)
{
int l=strlen(c);
int x=;
for(int i=;i<l;i++)
{
int t=idx(c[i]);
if(!a[x].son[t])
{
num++;
clear(num);
a[x].son[t]=num;
}
x=a[x].son[t];
}
ed[x]=;
} void buildAC()
{
while(!q.empty()) q.pop();
for(int i=;i<=S;i++)
if(a[].son[i]) q.push(a[].son[i]);
while(!q.empty())
{
int x=q.front();q.pop();
int fail=a[x].fail;
for(int i=;i<=S;i++)
{
int y=a[x].son[i];
if(y)
{
a[y].fail=a[fail].son[i];
ed[y]|=ed[a[fail].son[i]];
q.push(y);
}
else a[x].son[i]=a[fail].son[i];
}
}
} double count(int x,int l)
{
if(l==) return d[x][l]=1.0;
if(d[x][l]!=-) return d[x][l];
d[x][l]=;
for(int i=;i<=S;i++)
{
if(!pro[i]) continue;
int y=a[x].son[i];
if(!ed[y]) d[x][l]+=pro[i]*count(y,l-);
}
return d[x][l];
} int main()
{
freopen("a.in","r",stdin);
freopen("a.out","w",stdout);
int T,cas=;
scanf("%d",&T);
while(T--)
{
num=;
clear();
memset(cnt,,sizeof(cnt));
memset(ed,,sizeof(ed));
memset(pro,,sizeof(pro));
scanf("%d",&k);
for(int i=;i<=k;i++)
{
scanf("%s",s);
trie(s);
}
buildAC();
scanf("%d",&n);getchar();
for(int i=;i<=n;i++)
{
char c;
scanf("%c",&c);getchar();
scanf("%lf",&pro[idx(c)]);getchar();
}
scanf("%d",&l);
for(int i=;i<=num;i++)
for(int j=;j<=l;j++)
d[i][j]=-;
printf("Case #%d: %lf\n",++cas,count(,l));
}
return ;
}
【uva11468-Substring】AC自动机+dp的更多相关文章
- UVA11468 Substring --- AC自动机 + 概率DP
		UVA11468 Substring 题目描述: 给定一些子串T1...Tn 每次随机选择一个字符(概率会给出) 构造一个长为n的串S,求T1...Tn不是S的子串的概率 直接把T1...Tn建成AC ... 
- Codeforces 1015F Bracket Substring AC自动机 + dp
		Bracket Substring 这么垃圾的题怎么以前都不会写啊, 现在一眼怎么就会啊.... 考虑dp[ i ][ j ][ k ][ op ] 表示 已经填了 i 个空格, 末尾串匹配到 所给串 ... 
- POJ1625 Censored!(AC自动机+DP)
		题目问长度m不包含一些不文明单词的字符串有多少个. 依然是水水的AC自动机+DP..做完后发现居然和POJ2778是一道题,回过头来看都水水的... dp[i][j]表示长度i(在自动机转移i步)且后 ... 
- HDU2296 Ring(AC自动机+DP)
		题目是给几个带有价值的单词.而一个字符串的价值是 各单词在它里面出现次数*单词价值 的和,问长度不超过n的最大价值的字符串是什么? 依然是入门的AC自动机+DP题..不一样的是这题要输出具体方案,加个 ... 
- HDU2457 DNA repair(AC自动机+DP)
		题目一串DNA最少需要修改几个基因使其不包含一些致病DNA片段. 这道题应该是AC自动机+DP的入门题了,有POJ2778基础不难写出来. dp[i][j]表示原DNA前i位(在AC自动机上转移i步) ... 
- hdu 4117 GRE Words AC自动机DP
		题目:给出n个串,问最多能够选出多少个串,使得前面串是后面串的子串(按照输入顺序) 分析: 其实这题是这题SPOJ 7758. Growing Strings AC自动机DP的进阶版本,主题思想差不多 ... 
- hdu 2457(ac自动机+dp)
		题意:容易理解... 分析:这是一道比较简单的ac自动机+dp的题了,直接上代码. 代码实现: #include<stdio.h> #include<string.h> #in ... 
- HDU 2425 DNA repair (AC自动机+DP)
		DNA repair Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ... 
- HDU2296——Ring(AC自动机+DP)
		题意:输入N代表字符串长度,输入M代表喜欢的词语的个数,接下来是M个词语,然后是M个词语每个的价值.求字符串的最大价值.每个单词的价值就是单价*出现次数.单词可以重叠.如果不止一个答案,选择字典序最小 ... 
- tyvj P1519 博彩游戏(AC自动机+DP滚动数组)
		P1519 博彩游戏 背景 Bob最近迷上了一个博彩游戏…… 描述 这个游戏的规则是这样的:每花一块钱可以得到一个随机数R,花上N块钱就可以得到一个随机序列:有M个序列,如果某个序列是产生的随机序列的 ... 
随机推荐
- OrCAD设置原理图页面大小
			1. 右键要修改的原理图文件 2. 选择适合的尺寸 
- nginx location优先级
			目录 1. 配置语法 2. 配置实例 3. 总结: 网上查了下location的优先级规则,但是很多资料都说的模棱两可,自己动手实地配置了下,下面总结如下. 1. 配置语法 1> 精确匹配 lo ... 
- http报文和浏览器缓存机制
			目录 1. 请求报文 1.1请求行 1.2 请求头 一些常用的请求头信息 2. 响应报文 2.1 状态行 1> 响应状态码 2> 常见的响应状态码 2.2 响应头 3. 浏览器缓存 3.1 ... 
- 小程序如何去掉button组件的边框
			小程序获取用户授权不再支持wx.getUserInfo方法,改为用button获取,格式如下 <button class="btn btn" open-type=" ... 
- 正则表达式 Pattern和Matcher
			java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包. 1.简介: java.util.regex是一个用正则表达式所订制的模式来对字符串进行匹配工作的类库包. ... 
- Linux-ls,cd,type命令
			windows: dll:dynamic link library,动态链接库 Linux: .so:shared object,共享对象 操作系统: kernel:内核: 1.进程管理 2.内核管理 ... 
- 【java并发编程实战】第七章:取消与关闭
			停止线程的几种方式 一般的逻辑停止 public class ThreadInterruptTest { public static volatile boolean cancel = true; p ... 
- 【转】Linux学习(1)-常用快捷键、文件管理和查询
			原文链接:http://www.cnblogs.com/zhaopei/p/7397402.html 有话要说 为什么要用Linux?要用Linux的原因太多,想说说不完啊. 如果你说用Linux只是 ... 
- 剑指offer-二进制中1的个数11
			题目描述 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. class Solution: def NumberOf1(self, n): # write code here coun ... 
- Dijkstra标准模板
			Dijkstra求最短路问题:单元求最短路,从任意点出发求得该点到达其他任意点的距离 Dijkstra其实是一种贪心策略,与出发点(即源点)所连接的点中找到距离最短的点(这个距离是源点到这个点的最短距 ... 
