HDU-1251 统计难题(前缀树)
来源:互联网 发布:网络电视如何使用 编辑:程序博客网 时间:2024/04/29 19:52
统计难题
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131070/65535 K (Java/Others)Total Submission(s): 30080 Accepted Submission(s): 11716
Problem Description
Ignatius最近遇到一个难题,老师交给他很多单词(只有小写字母组成,不会有重复的单词出现),现在老师要他统计出以某个字符串为前缀的单词数量(单词本身也是自己的前缀).
Input
输入数据的第一部分是一张单词表,每行一个单词,单词的长度不超过10,它们代表的是老师交给Ignatius统计的单词,一个空行代表单词表的结束.第二部分是一连串的提问,每行一个提问,每个提问都是一个字符串.
注意:本题只有一组测试数据,处理到文件结束.
注意:本题只有一组测试数据,处理到文件结束.
Output
对于每个提问,给出以该字符串为前缀的单词的数量.
Sample Input
bananabandbeeabsoluteacmbabbandabc
Sample Output
2310
此题为前缀树保存字符串集合的问题,在前缀树中,一般设置一个数组保存每个节点的信息,在此处直接就是保存经过此节点的单词个数,最后找到之后输出就可以了。
代码:
#include<iostream>#include<cstdio>#include<map>#include<math.h>#include<cstring>#include<algorithm>using namespace std;#define sigma_size 26#define maxnode 1000000 + 10struct Trie{ int ch[maxnode][sigma_size]; int val[maxnode];//val数组保存节点信息 int sz; void trie() { sz = 1; memset(ch[0],0, sizeof(ch[0])); } void Insert(char * s) { int u = 0, n = strlen(s); for(int i = 0; i < n; i++) { int c = s[i] - 'a'; if(!ch[u][c]) { memset(ch[sz], 0, sizeof(ch[sz])); val[sz] = 1; ch[u][c] = sz++; } else val[ch[u][c]]++;//每次只要经过之后,节点加一 u = ch[u][c]; } }};Trie Word;int Find(char * s){ int i; int u = 0; int n = strlen(s); for(i = 0; i < n; i++) { int c = s[i] - 'a'; if(!Word.ch[u][c])//如果某处直接没有前缀返回0 return 0; else u = Word.ch[u][c]; } return Word.val[u];}int main(){ char s[15]; Word.trie(); while(gets(s)) { if(strcmp(s,"") == 0) break; Word.Insert(s); } char str[14]; int u, i; while(gets(str)) { printf("%d\n",Find(str)); } return 0;}
0 0
- HDU-1251 统计难题(前缀树)
- HDU 1251-统计难题(字典树-统计前缀串)
- hdu 1251 统计难题 (前缀树)
- HDU 1251 统计难题(字典树,统计前缀个数)
- HDU 1251 统计难题-字典树-统计前缀个数
- hdu 1251 统计难题 (统计前缀出现次数)
- HDU 1251 统计难题(字典树(统计前缀数量) || map运用)
- HDU 1251 统计难题(统计以某个字符串为前缀的字符串数量)
- HDU 1251统计难题(字典树)
- hdu 1251 统计难题(trie树)
- hdu 1251 统计难题(字典树)
- hdu 1251 统计难题(字典树)
- hdu 1251 统计难题(字典树)
- hdu 1251 统计难题 (字典树)
- hdu 1251 统计难题(字典树)
- HDU 1251 统计难题(字典树)
- HDU 1251 统计难题(字典树)
- HDU 1251 统计难题(字典树)
- unity 调用安卓系统摄像机和相册并对图片进行裁剪(一)
- Linux cat命令详解
- LeetCode---Isomorphic Strings、Word Pattern解题分析
- java 转义符小结
- 57-004-1 bootstrap定义一个导航页面包括bootstrap面板,表格,分页,胶囊导航等样式
- HDU-1251 统计难题(前缀树)
- OC开发 --- 连式语法API设计 (使用block)
- Java NIO系列教程(二) Channel
- CSS 多列等高
- 1、神经网络
- Mysql取某个范围内随机日期 FLOOR和LPAD
- c++构造函数详解
- css 图片适应浏览器大小
- Java学习之封装