HDU 2222 Keywords Search(查询关键字)
HDU 2222 Keywords Search(查询关键字)
Time Limit: 2000/1000 MS (Java/Others)
Memory Limit: 131072/131072 K (Java/Others)
|
【Description】 |
【题目描述】 |
|
In the modern time, Search engine came into the life of everybody like Google, Baidu, etc. Wiskey also wants to bring this feature to his image retrieval system. Every image have a long description, when users type some keywords to find the image, the system will match the keywords with description of image and show the image which the most keywords be matched. To simplify the problem, giving you a description of image, and some keywords, you should tell me how many keywords will be match. |
当今社会,诸如谷歌,百度等搜索引擎不断深入人心。 Wiskey想把这个功能加入他的图片搜索系统。 每张图都有一串很长的描述,当用户输入一些关键字去搜索图片时,系统会匹配描述图片的关键字并显示有最多关键字匹配的图片。 |
|
【Input】 |
【输入】 |
|
First line will contain one integer means how many cases will follow by. Each case will contain one integers N means the number of keywords and N keywords follow. (N <= 10000) Each keyword will only contains characters 'a'-'z', and the length will be not longer than 50. The last line is the description, and the length will be not longer than 1000000. |
第一行有一个整数随后测试用例数量。 每个测试用例。 每个测试用例有一个整数N表示关键字数量与随后有N个关键字。(N <= 10000) 每个关键字只包含字符'a'-'z',并且其长度不大于50。 最后一行是此图片的描述,并且其长度不大于1000000。 |
|
【Output】 |
【输出】 |
|
Print how many keywords are contained in the description. |
输出描述中包含的关键字数量。 |
|
【Sample Input - 输入样例】 |
【Sample Output - 输出样例】 |
|
1 5 she he say shr her yasherhs |
3 |
【题解】
AC自动机入门题,不过数据不全面,里面没有考虑回头匹配子串情况的数据(个人觉得这是KMP的AC自动机的主要不同之处,Trie图不会,哪天被打脸了再说)
例如:
1
2
abc
b
abc
输出1的代码居然也能A……而且貌似这个问题被提出来很久了,一直没有改善。
注意匹配的是关键字数量,关键字可以相同,不过可以看成匹配一个关键字就去掉一个关键字。
【代码 C++】
#include <cstdio>
#include <cstring>
#include <queue>
struct Node{
int next[], fail, isWord;
}tr[];
int it;
char text[]; void build(){
it = ;
memset(tr, , sizeof(tr));
int n, i, j, w;
char word[];
scanf("%d", &n), getchar();
while (n--){
gets(word);
for (i = j = ; word[i]; ++i){
w = word[i] - 'a';
if (!tr[j].next[w]) tr[j].next[w] = ++it;
j = tr[j].next[w];
}
++tr[j].isWord;
}
}
void setFail(){
std::queue<int> q, last;
int now, pre, next, i, j;
for (i = ; i < ; ++i){
if (tr[].next[i]) q.push(tr[].next[i]), last.push();
} while (!q.empty()){
now = q.front(); q.pop();
pre = last.front(); last.pop();
for (i = ; i < ; ++i){
next = tr[now].next[i];
if (next){
q.push(next);
if (tr[pre].next[i]) j = pre;
else j = ;
if (tr[j].next[i]){
tr[next].fail = tr[j].next[i];
last.push(tr[j].next[i]);
}
else last.push();
}
}
}
}
int fid(){
gets(text);
int i, iTR, opt, w, temp;
for (i = iTR = opt = ; text[i]; ++i){
w = text[i] - 'a';
if (tr[iTR].next[w]) iTR = tr[iTR].next[w];
else{
if (iTR) --i;
iTR = tr[iTR].fail;
}
for (temp = iTR; ~tr[temp].isWord; temp = tr[temp].fail){
opt += tr[temp].isWord;
tr[temp].isWord = -;
}
}
return opt;
}
int main(){
int t;
scanf("%d", &t);
while (t--){
build();
setFail();
printf("%d\n", fid());
}
return ;
}
自己面向图片编程的代码……
#include <cstdio>
#include <cstring>
#include <queue>
struct Node{
int next[], fail, isWord;
}tr[];
int it; void build(){
it = ;
memset(tr, , sizeof(tr));
int n, i, j, w;
char word[];
scanf("%d", &n), getchar();
while (n--){
gets(word);
for (i = j = ; word[i]; ++i){
w = word[i] - 'a';
if (!tr[j].next[w]) tr[j].next[w] = ++it;
j = tr[j].next[w];
}
++tr[j].isWord;
}
}
void setFail(){
std::queue<int> q;
int now, next, i;
for (i = ; i < ; ++i) if (tr[].next[i]) q.push(tr[].next[i]); while (!q.empty()){
now = q.front(); q.pop();
for (i = ; i < ; ++i){
if (next = tr[now].next[i]){
q.push(next);
tr[next].fail = tr[tr[now].fail].next[i];
}
else tr[now].next[i] = tr[tr[now].fail].next[i];
}
}
}
int fid(){
char text[];
gets(text);
int i, iTR, opt, temp;
for (i = iTR = opt = ; text[i]; ++i){
iTR = tr[iTR].next[text[i] - 'a'];
for (temp = iTR; ~tr[temp].isWord; temp = tr[temp].fail){
opt += tr[temp].isWord;
tr[temp].isWord = -;
}
}
return opt;
}
int main(){
int t;
scanf("%d", &t);
while (t--){
build();
setFail();
printf("%d\n", fid());
}
return ;
}
参考kuangbin巨后稍微简化的代码
HDU 2222 Keywords Search(查询关键字)的更多相关文章
- HDU 2222 Keywords Search(AC自动机模版题)
Keywords Search Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others ...
- HDU 2222 Keywords Search(瞎搞)
Keywords Search Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others ...
- hdu 2222 Keywords Search ac自己主动机
点击打开链接题目链接 Keywords Search Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Ja ...
- hdu 2222 Keywords Search 模板题
Keywords Search Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others ...
- hdu 2222 Keywords Search - Aho-Corasick自动机
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Submissio ...
- hdu 2222 Keywords Search ac自动机入门
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2222 题意:有N(N <= 10000)个长度不超过50的模式串和一个长度不超过1e6的文本串. ...
- hdu 2222 Keywords Search
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2222 思路:裸AC自动机,直接贴代码做模板 #include<stdio.h> #includ ...
- HDU 2222 Keywords Search(AC自动机模板题)
http://acm.hdu.edu.cn/showproblem.php?pid=2222 题意:给出多个单词,最后再给出一个模式串,求在该模式串中包含了多少个单词. 思路: AC自动机的模板题. ...
- 【刷题】HDU 2222 Keywords Search
Problem Description In the modern time, Search engine came into the life of everybody like Google, B ...
随机推荐
- 深入研究java.lang.Runtime类【转】
转自:http://blog.csdn.net/lastsweetop/article/details/3961911 目录(?)[-] javalang 类 Runtime getRuntime e ...
- linux添加somebody到组
添加xiluhua到组:test_group usermod -a test_group xiluhua
- 几个常见的Laravel报错及解决方法
报错:「Can't swap PDO instance while within transaction」 transactions >= 1) {throw new RuntimeExcept ...
- 如何在VS2013中新建WindowsService定时任务
http://jingyan.baidu.com/article/cd4c2979e9330d756f6e6070.html 很多人都想做定时任务,但是没有不知道如何下手,现在就用WindowsSer ...
- PHP的一些常用汇总
1. 使用strcmp()函数[区分大小写] 和strcasecmp()函数按照字节比较.比较结果显示:前和后相同为0,前>后为大于0,前<后为小于0. 2. 格式化字符串:number_ ...
- java 错误集锦
Exception in thread "main" java.lang.Error: Unresolved compilation problem: at com.niuniu. ...
- Redis 安装 启动 连接 配置 重启
Linux下安装 ]# wget http://download.redis.io/releases/redis-2.8.17.tar.gz ]# .tar.gz ]# cd redis- ]# ma ...
- [BIM]BIM中IFD介绍
第三大支柱IFD - 确定交换的信息和你要的信息是同一个东西 IFD的全称是International Framework for Dictionaries,中文可以叫“国际字典框架”,和前两者IFC ...
- ACM题目————二叉树的遍历
一.二叉树的后序遍历: 题目描述 给定一颗二叉树,要求输出二叉树的深度以及后序遍历二叉树得到的序列.本题假设二叉树的结点数不超过1000 输入 输 入数据分为多组,第一行是测试数据的组数n,下面的n行 ...
- ACM题目————列变位法解密
这是在百度之星看到的. Problem Description 列变位法是古典密码算法中变位加密的一种方法,具体过程如下 将明文字符分割成个数固定的分组(如5个一组,5即为密钥),按一组一行的次序整齐 ...