统计难题

Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131070/65535 K (Java/Others)
Total Submission(s): 15031    Accepted Submission(s): 6436

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

注意:本题只有一组测试数据,处理到文件结束.

 
Output
对于每个提问,给出以该字符串为前缀的单词的数量.
 
Sample Input
banana
band
bee
absolute
acm

ba
b
band
abc

 
Sample Output
2 3 1 0
 
思路:字典树
AC代码:
 #include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct Tree_Node
{
int cnt;
struct Tree_Node *child[];
}Node;
Node *root;
char str[];
void insert()
{
int i;
if(str == NULL)
return ;
char *p = str;
Node *t = root;
while(*p != '\0')
{
if(NULL == t -> child[*p- 'a'])
{
Node *temp = (Node *)malloc(sizeof(Node));
memset(temp, , sizeof(Node));
for(i = ;i < ;i ++)
{
temp -> child[i] = NULL;
temp -> cnt = ;
}
t -> child[*p - 'a'] = temp;
}
t = t -> child[*p - 'a'];
t -> cnt ++;
p ++;
}
}
int search()
{
if(NULL == root)
return ;
char *p = str;
Node *t = root;
while(*p != '\0')
{
if(NULL != t -> child[*p - 'a'])
{
t = t -> child[*p - 'a'];
p ++;
}
else
return ;
}
return t -> cnt;
} int main(int argc, char const *argv[])
{
int i;
char c[] = "abc";
Node TREEROOT;
root = &TREEROOT;
for(i = ;i < ;i ++)
{
root -> child[i] = NULL;
root -> cnt = ;
}
// freopen("in.c","r",stdin);
while(gets(str) && strcmp(str,""))
{
insert();
memset(str, , sizeof(str));
}
memset(str, , sizeof(str));
while(~scanf("%s", str))
{
printf("%d\n", search());
memset(str, , sizeof(str));
}
return ;
}

最新文章

  1. 烂泥:智能DNS使用与配置
  2. centos 6.x安装rvm 配置 Ruby开发环境
  3. JavasSript实现秒转换为“天时分秒”控件和TDD测试方法应用
  4. 动手学习TCP:TCP连接建立与终止
  5. 【阿里云产品公测】ACE安装wordpress博客图文教程
  6. php访问类静态属性
  7. Java基础(三)
  8. google官方提供的下拉刷新控件SwipeRefreshLayout
  9. 【Daily】 2014-4-28
  10. poj 1068 Parencodings(栈)
  11. JVM内存模型,垃圾回收算法
  12. PHPUnit使用教程——PHP环境变量+x-debug+composer+phpunit配置安装(超详细!)
  13. [BZOJ]1069 最大土地面积(SCOI2007)
  14. LeetCode(34)-Palindrome Number
  15. QT读取xml配置文件
  16. CF1153C Serval and Parenthesis Sequence
  17. markdown文本转换word,pdf
  18. SDL播放YUV----单帧
  19. 每天一个linux命令(7):mv
  20. javascript里文字选中/选中文字

热门文章

  1. java新手笔记13 继承
  2. Java 的自动装箱拆箱
  3. Codevs 5208 求乘方取模
  4. 实例:图形绘制[OpenCV 笔记15]
  5. 代码方式删除SVN
  6. mini2440移植uboot-2008.10 (一)
  7. 常用的工具GCC GDB Make Makefile
  8. 【pyhton】成员资格运算符
  9. 网站seo优化--jsoup 批量分析相关网站 标签,描述,关键词.
  10. sitecustomize.py 用法