统计难题

Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131070/65535 K (Java/Others)

Total Submission(s): 22291    Accepted Submission(s): 9424

Problem Description
Ignatius近期遇到一个难题,老师交给他非常多单词(仅仅有小写字母组成,不会有反复的单词出现),如今老师要他统计出以某个字符串为前缀的单词数量(单词本身也是自己的前缀).
 
Input
输入数据的第一部分是一张单词表,每行一个单词,单词的长度不超过10,它们代表的是老师交给Ignatius统计的单词,一个空行代表单词表的结束.第二部分是一连串的提问,每行一个提问,每一个提问都是一个字符串.



注意:本题仅仅有一组測试数据,处理到文件结束.
 
Output
对于每一个提问,给出以该字符串为前缀的单词的数量.
 
Sample Input
banana
band
bee
absolute
acm ba
b
band
abc
 
Sample Output
2
3
1
0
 
Author
Ignatius.L
 
Recommend
 

题解:建一颗字典树,然后查询出现的次数即可了。

#include<cstring>
#include<cstdio>
#include<algorithm>
#include<iostream>
#include<cmath>
#include<vector>
#include<cstring>
#define N 10010 using namespace std; int n;
char s[N]; typedef struct tire {
int num;
struct tire *net[26];
}*Tire; void Init(Tire &p) {
p=(Tire)malloc(sizeof(tire));
p->num=0;
for(int i=0; i<26; i++) {
p->net[i]=NULL;
}
} void CreatTire(Tire &p,char s[]) {
int i=0;
Tire q=p;
while(s[i]) {
int nx=s[i]-'a';
if(q->net[nx]==NULL) {
Init(q->net[nx]);
q->net[nx]->num=1;
} else {
q->net[nx]->num++;
}
q=q->net[nx];
i++;
}
} int Serch(Tire p,char s[]) {
int i=0;
Tire q=p;
while(s[i]) {
int nx=s[i]-'a';
if(q->net[nx]==NULL)return 0;
q=q->net[nx];
i++;
}
return q->num;
} int main() {
//freopen("test.in","r",stdin);
Tire p;
Init(p);
while(gets(s)!=NULL&&s[0]!='\0') {
CreatTire(p,s);
}
while(~scanf("%s",s)) {
printf("%d\n",Serch(p,s));
}
return 0;
}

最新文章

  1. 使用KRPano资源分析工具还原全景图片
  2. EF Fluent API上
  3. Python set集合类型操作总结
  4. 【TypeScript】如何在TypeScript中使用async/await,让你的代码更像C#。
  5. Unity multi_compile
  6. 【FFXV】中物理模拟的结构以及游戏业界的乐趣
  7. 九度oj 1541 二叉树
  8. asp.net viewstate的模拟登陆
  9. java实现网络爬虫
  10. C# bootstrap之表格动态绑定值
  11. Lodop打印设计矩形重合预览线条变粗
  12. 前端 HTML body标签相关内容 常用标签 盒子标签 div
  13. centos6.8下配置https服务器
  14. Java技术----Java泛型详解
  15. [算法]和为S的连续正数序列
  16. NSDate 时间加减
  17. sweetalert 快速显示两个提示, 第二个显示不出的问题
  18. linux远程win7教程
  19. POJ1220 Number Base Conversion
  20. 543. Diameter of Binary Tree 二叉树的最大直径

热门文章

  1. 逻辑漏洞-客户端验证的邮箱-Web渗透实例之中国教育部青少年普法网站逻辑漏洞
  2. 辛星和你彻底搞清CSS中的相对定位和绝对定位
  3. spring quartz定时任务 配置
  4. MapReduce实战(七)GroupingComparator
  5. js控制button
  6. [Idea Fragments] PostScript for 3D Print??
  7. 常用cms
  8. 第二百一十五节,jQuery EasyUI,DateBox(日期输入框)组件
  9. Web监听器导图详解
  10. CentOS7.1 安装Liberty之环境准备(1)