bzoj 1212: [HNOI2004]L语言

时间:2021-08-19 17:13:19

思路:字典树+dp, dp[ i ] 表示 前缀到 i 能不能被理解, 如果dp[ i ] 是能被理解的那么, 把i + 1, i + 2 ....  在字典树上走,走到一个单词就转移。

,这样可行的原因是因为模板串长度不超过10,所以字典树的深度不会超过10, 所以进行一次dp的复杂度为 10 * n;

 #include<bits/stdc++.h>
#define LL long long
#define ll long long
#define fi first
#define se second
#define mk make_pair
#define pii pair<int,int>
#define piii pair<int, pair<int,int> > using namespace std; const int N = 1e6 + ;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9 + ;
const int Mod = ; int ch[][], tot, n, m;
bool is[], dp[N];
char s[N];
int getNode() {
++tot;
memset(ch[tot], , sizeof(ch[tot]));
is[tot] = false;
return tot;
} void add(const char *s, int n) {
int u = ;
for(int i = ; i < n; i++) {
if(!ch[u][s[i] - 'a']) {
ch[u][s[i] - 'a'] = getNode();
}
u = ch[u][s[i] - 'a'];
}
is[u] = true;
} int main() {
scanf("%d%d", &n, &m);
for(int i = ; i <= n; i++) {
scanf("%s", s);
add(s, strlen(s));
} while(m--) {
memset(dp, false, sizeof(dp));
scanf("%s", s + );
n = strlen(s + );
dp[] = true;
for(int i = ; i < n; i++) {
if(dp[i]) {
int j = i + , u = ;
while(j <= n && ch[u][s[j] - 'a']) {
u = ch[u][s[j] - 'a'];
if(is[u]) dp[j] = true;
j++;
}
}
} int ans = ;
for(int i = ; i <= n; i++)
if(dp[i]) ans = i;
printf("%d\n", ans);
}
return ;
} /*
*/

bzoj 1212: [HNOI2004]L语言的更多相关文章

  1. BZOJ 1212&colon; &lbrack;HNOI2004&rsqb;L语言 &lbrack;AC自动机 DP&rsqb;

    1212: [HNOI2004]L语言 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1367  Solved: 598[Submit][Status ...

  2. BZOJ 1212&colon; &lbrack;HNOI2004&rsqb;L语言&lpar; dp &plus; trie &rpar;

    因为单词很短...用trie然后每次dp暴力查找...用哈希+dp应该也是可以的.... ------------------------------------------------------- ...

  3. BZOJ 1212 &lbrack;HNOI2004&rsqb;L语言 【AC自动机 &plus; 背包】

    题目链接[http://www.lydsy.com/JudgeOnline/problem.php?id=1212] 题意:给你一些单词,然后给出一个没有标点的文本串S,都是小写字符.现在让你求用给出 ...

  4. BZOJ 1212 HNOI2004 L语言 AC自己主动机&lpar;Trie树&rpar;&plus;动态规划

    标题效果:给定词的列表,并m串 每个字符串q个最长前缀,这个前缀可满足拆分成一些字符串 这些字符串中存在的词汇太 再也不怕错误的数据范围--有一个很明显Trie树能解决的问题竟然被我写的AC自己主动机 ...

  5. bzoj 1212&colon; &lbrack;HNOI2004&rsqb;L语言 AC自动机&plus;状压

    为什么这道题网上所有题解写的都是N*Len的trie树的暴力啊,4E的复杂度... 为什么暴力还跑这么快啊TAT.. 有一个O(Len)的做法就是先把AC自动机建出来,因为每个字典串的长度很小,所以我 ...

  6. BZOJ 1212&colon; &lbrack;HNOI2004&rsqb;L语言 trie

    长度小于 10 是关键信息~ #include <cstdio> #include <cstring> #include <algorithm> #define N ...

  7. 1212&colon; &lbrack;HNOI2004&rsqb;L语言

    1212: [HNOI2004]L语言 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 643  Solved: 252[Submit][Status] ...

  8. BZOJ P1212 &lbrack;HNOI2004&rsqb; L语言

    标点符号的出现晚于文字的出现,所以以前的语言都是没有标点的.现在你要处理的就是一段没有标点的文章. 一段文章T是由若干小写字母构成.一个单词W也是由若干小写字母构成.一个字典D是若干个单词的集合. 我 ...

  9. bzoj1212&colon; &lbrack;HNOI2004&rsqb;L语言(字典树)

    1212: [HNOI2004]L语言 题目:传送门 题解: 看完题目之后就觉得可以暴力在字典树上之间询问,一开始还傻了以为用文章来建,肯定用单词啊: 那么我们可以用一个v数组表示当前字符串1~i的区 ...

随机推荐

  1. &period;NET基础拾遗(1)类型语法基础和内存管理基础

    Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开发基 ...

  2. 【代码笔记】iOS-获得富文本设置以后的文字高度

    一,效果图. 二,工程图. 三,代码. RootViewController.h #import <UIKit/UIKit.h> @interface RootViewController ...

  3. ImageView设置边框的两种方式

    转载:http://www.2cto.com/kf/201308/239945.html package cc.testimageviewbounds; import android.os.Bundl ...

  4. &lpar;int&rpar;、int&period;Parse&lpar;&rpar;、int&period;TryParse&lpar;&rpar;和Convert&period;ToInt32&lpar;&rpar;的区别

    C#中(int).int.Parse().int.TryParse()和Convert.ToInt32()的区别   原文链接:http://www.cnblogs.com/leolis/p/3968 ...

  5. C&num; DataTable 和List之间相互转换的方法

    介绍:List/IEnumerable转换到DataTable/DataView,以及DataTable转换到List 正文: 一.List<T>/IEnumerable转换到DataTa ...

  6. 欧拉函数 &amp&semi;【POJ 2478】欧拉筛法

    通式: $\phi(x)=x(1-\frac{1}{p_1})(1-\frac{1}{p_2})(1-\frac{1}{p_3}) \cdots (1-\frac{1}{p_n})$ 若n是质数p的k ...

  7. 《Algorithms 4th Edition》读书笔记——2&period;4 优先队列&lpar;priority queue&rpar;-Ⅴ

    命题Q.对于一个含有N个元素的基于堆叠优先队列,插入元素操作只需要不超过(lgN + 1)次比较,删除最大元素的操作需要不超过2lgN次比较. 证明.由命题P可知,两种操作都需要在根节点和堆底之间移动 ...

  8. express框架&plus;jade&plus;bootstrap&plus;mysql开发用户注册登录项目

    完整的项目代码(github):https://github.com/suqinhui/express-demo express是基于Node.js平台的web应用开发框架,用express框架开发w ...

  9. 移动端WEBAPP开发遇到的坑,以及填坑方案!持续更新~~~~

    前言:在移动端WEBAPP开发中会遇到各种各样的问题,通过此文对遇到的问题做一个归纳总结,方便自己日后查询,也给各位前端开发友人做一个参考.   此文中涉及的问题是本人开发中遇到的,解决方案是本人思考 ...

  10. Java 多线程(一) 基础知识与概念

    多线程Multi-Thread 基础 线程概念 线程就是程序中单独顺序的流控制. 线程本身不能运行,它只能用于程序中. 说明:线程是程序内的顺序控制流,只能使用分配给程序的资源和环境. 进程 进程:执 ...