uva 11468 Substring
题意:给你 k 个模板串,然后给你一些字符的出现概率,然后给你一个长度 l ,问你这些字符组成的长度为 l 的字符串不包含任何一个模板串的概率。
思路:AC自动机+概论DP
首先用K个模板构造好AC自动机。题目上说长L的新串的子串不包含任何一个K串,其实就是说在构造好的树中,从根往下走L步都不包含K个模板。此题用match标记是否为K模板串。
状态转移方程代码中注释了。
- #include<cstdio>
- #include<cstring>
- #include<queue>
- #include<cstdio>
- #include<map>
- #include<string>
- using namespace std;
- const int SIGMA_SIZE = ;
- const int MAXNODE = ; // 结点总数
- const int MAXS = + ; // 模板个数
- int idx[], n;
- double prob[SIGMA_SIZE];
- struct AhoCorasickAutomata
- {
- int ch[MAXNODE][SIGMA_SIZE];
- int f[MAXNODE]; // fail函数
- int match[MAXNODE]; // 是否包含某一个字符串
- int sz; // 结点总数
- void init()
- {
- sz = ;
- memset(ch[], , sizeof(ch[]));
- }
- // 插入字符串
- void insert(char *s)
- {
- int u = , n = strlen(s);
- for(int i = ; i < n; i++)
- {
- int c = idx[s[i]];
- if(!ch[u][c])
- {
- memset(ch[sz], , sizeof(ch[sz]));
- match[sz] = ;
- ch[u][c] = sz++;
- }
- u = ch[u][c];
- }
- match[u] = ;
- }
- // 计算fail函数
- void getFail()
- {
- queue<int> q;
- f[] = ;
- // 初始化队列
- for(int c = ; c < SIGMA_SIZE; c++)
- {
- int u = ch[][c];
- if(u)
- {
- f[u] = ;
- q.push(u);
- }
- }
- // 按BFS顺序计算fail
- while(!q.empty())
- {
- int r = q.front();
- q.pop();
- for(int c = ; c < SIGMA_SIZE; c++)
- {
- int u = ch[r][c];
- if(!u)
- {
- ch[r][c] = ch[f[r]][c];
- continue;
- }
- q.push(u);
- int v = f[r];
- while(v && !ch[v][c]) v = f[v];
- f[u] = ch[v][c];
- match[u] |= match[f[u]];
- }
- }
- }
- };
- AhoCorasickAutomata ac;
- double d[MAXNODE][];
- int vis[MAXNODE][];
- double getProb(int u, int L)//d[u][L]=prob[u]*d[v][L-1]状态转方程 v为u的儿子可以走节点
- {
- if(!L) return 1.0;
- if(vis[u][L])
- return d[u][L];
- vis[u][L] = ;
- d[u][L]=0.0;
- for(int i = ; i < n; i++)
- if(!ac.match[ac.ch[u][i]])
- d[u][L] += prob[i] * getProb(ac.ch[u][i], L-);
- return d[u][L];
- }
- char s[][];
- int main()
- {
- int T;
- scanf("%d", &T);
- for(int kase = ; kase <= T; kase++)
- {
- int k, L;
- scanf("%d", &k);
- for(int i = ; i < k; i++) scanf("%s", s[i]);
- scanf("%d", &n);
- for(int i = ; i < n; i++)
- {
- char ch[];
- scanf("%s%lf", ch, &prob[i]);
- idx[ch[]] = i;
- }
- ac.init();
- for(int i = ; i < k; i++) ac.insert(s[i]);
- ac.getFail();
- scanf("%d", &L);
- memset(vis, , sizeof(vis));
- memset(d,,sizeof(d));
- printf("Case #%d: %.6lf\n", kase, getProb(, L));
- }
- return ;
- }
uva 11468 Substring的更多相关文章
- uva 11468 - Substring(AC自己主动机+概率)
题目链接:uva 11468 - Substring 题目大意:给出一些字符和各自字符相应的选择概率.随机选择L次后得到一个长度为L的字符串,要求该字符串不包括随意一个子串的概率. 解题思路:构造AC ...
- AC自动机+全概率+记忆化DP UVA 11468 Substring
题目传送门 题意:训练指南P217 分析:没有模板串也就是在自动机上走L步,不走到val[u] == v的节点的概率 PS:边读边insert WA了,有毒啊! #include <bits/s ...
- 沉迷AC自动机无法自拔之:[UVA 11468] Substring
图片加载可能有点慢,请跳过题面先看题解,谢谢 这个鬼题目,上一波套路好了 先用题目给的模板串建\(AC\)自动机,把单词结尾标记为 \(val=1\),然后在建好的\(AC\)自动机上跑 \(dp\) ...
- UVa 11468 Substring (AC自动机+概率DP)
题意:给出一个字母表以及每个字母出现的概率.再给出一些模板串S.从字母表中每次随机拿出一个字母,一共拿L次组成一个产度为L的串, 问这个串不包含S中任何一个串的概率为多少? 析:先构造一个AC自动机, ...
- UVA 11468 Substring (AC自动机)
用把失配边也加到正常边以后AC自动机,状态是长度递减的DAG,每次选一个不会匹配字符的转移. dp[u][L]表示当前在tire树上u结点长度还剩L时候不匹配的概率,根据全概率公式跑记忆化搜索. #i ...
- UVA 11468 Substring (记忆化搜索 + AC自动鸡)
传送门 题意: 给你K个模式串, 然后,再给你 n 个字符, 和它们出现的概率 p[ i ], 模式串肯定由给定的字符组成. 且所有字符,要么是数字,要么是大小写字母. 问你生成一个长度为L的串,不包 ...
- Uva 11468 AC自动机或运算
AC自动机 UVa 11468 题意:给一些字符和各自出现的概率,在其中随机选择L次,形成长度为L的字符串S,给定K个模板串,求S不包含任意一个串的概率. 首先介绍改良版的AC自动机: 传统的AC自动 ...
- UVa 11468 (AC自动机 概率DP) Substring
将K个模板串构成一个AC自动机,那些能匹配到的单词节点都称之为禁止节点. 然后问题就变成了在Tire树上走L步且不经过禁止节点的概率. 根据全概率公式用记忆化搜索求解. #include <cs ...
- UVA - 11468:Substring
随机生成一个字符可以看成在AC自动机里面向前走一个节点,那么ans就是0向前走L步并且不经过单词节点, 由概率知识可得,f[p][L]=∑f[nxt[p][i]][L-1]*g[i] 其中p表示位于p ...
随机推荐
- 如何使用PHP实现一个WebService
WSDL WSDL(网络服务描述语言,Web Services Description Language)是一门基于 XML 的语言,用于描述 Web Services 以及如何对它们进行访问.这种文 ...
- dtp--eclipse的安装数据源管理的一个插件的安装方法
1. 下载eclipse dtp 插件 http://download.eclipse.org/datatools/updates/1.11 help——>install new softwa ...
- java 串口通信 代码
下面是我自己实现的串口接收的类,串口发送比较简单,就直接发送就可以了.下面的这个类可以直接使用. package com.boomdts.weather_monitor.util; import ja ...
- iOS开发--TableView详细解释
-.建立 UITableView DataTable = [[UITableView alloc] initWithFrame:CGRectMake(0, 0, 320, 420)]; [Data ...
- AD15高版软件卡不卡,问题解决大讨论
AD高版软件很卡(包括13 14 15版),这是我遇到过的问题,大家都遇到过的问题, 这里我分享一个解决办法:也请给位有什么好的方法也一起分享. 问题1卡:打开AD15软件, 按住鼠标中键 放大 或 ...
- C# Winform应用程序占用内存较大解决方法整理
微软的 .NET FRAMEWORK 现在可谓如火如荼了.但是,.NET 一直所为人诟病的就是“胃口太大”,狂吃内存,虽然微软声称 GC 的功能和智能化都很高,但是内存的回收问题,一直存在困扰,尤其 ...
- 关于JavaScript中的setTimeout()链式调用和setInterval()探索
http://www.cnblogs.com/Wenwang/archive/2012/01/06/2314283.html http://www.cnblogs.com/yangjunhua/arc ...
- 【原创】oracle的tpc-c测试及方法
大家好,很高兴来到博客园分享自己的所见所得.希望和大家多多交流,共同进步. 本文重点在于简介使用BenchmarkSQL对oracle进行tpcc的测试步骤,只是一个简单入门的过程. 开源测试工具:B ...
- 安装TokuDB引擎
前言:TokuDB 是一个高性能.支持事务处理的 MySQL 和 MariaDB 的存储引擎.TokuDB 的主要特点是高压缩比,高 INSERT 性能,支持大多数在线修改索引.添加字段,非常适合日志 ...
- 命令行下玩VC
说明:(1)转载请注明出处:http://www.cnblogs.com/opangle/p/4298155.html (2)以下以VS2013为例,并假设VC安装路径为%VC_INSTALL_PAT ...