字典树 统计难题
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAX 26
struct Trie {
Trie *next[MAX];
int v;
};
Trie *root;
void creattrie(char *str)
{
Trie *p, *q;
int t, len, i, j;
p = root;
len = strlen(str);
for (i = 0; i < len; i++) {
t = str[i] - 'a';
if(p->next[t] == NULL) {
q = new Trie;
q->v = 1;
for (j = 0; j < MAX; j++)
q->next[j] = NULL;
p->next[t] = q;
p = p->next[t];
}
else {
p->next[t]->v++;
p = p->next[t];
}
// p->v = -1;
}
}
int findtrie(char *str)
{
int i, j, len, t;
Trie *p;
p = root;
len = strlen(str);
for (i = 0; i < len; i++) {
t = str[i] - 'a';
p = p->next[t];
if(p == NULL)
return 0;
}
return p->v;
}
int main( )
{
int i;
char str[20],ch[20];
root = new Trie;
for (i = 0; i < MAX; i++)
root->next[i] = NULL;
while(gets(str) && str[0] != '\0'){
creattrie(str);
}
while(scanf("%s",ch) != EOF)
printf("%d\n",findtrie(ch));
return 0;
}
posted on 2011-07-20 11:33 more think, more gains 阅读(158) 评论(0) 收藏 举报
 
                     
                    
                 
                    
                 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号 
