首页 > 其他 > 详细

Trie树统计单词前缀

时间:2014-11-17 22:55:43      阅读:561      评论:0      收藏:0      [点我收藏+]

输入

输入的第一行为一个正整数n,表示词典的大小,其后n行,每一行一个单词(不保证是英文单词,也有可能是火星文单词哦),单词由不超过10个的小写英文字母组成,可能存在相同的单词,此时应将其视作不同的单词。接下来的一行为一个正整数m,表示小Hi询问的次数,其后m行,每一行一个字符串,该字符串由不超过10个的小写英文字母组成,表示小Hi的一个询问。

输出

对于小Hi的每一个询问,输出一个整数Ans,表示词典中以小Hi给出的字符串为前缀的单词的个数。

样例输入
5
babaab
babbbaaaa
abba
aaaaabaa
babaababb
5
babb
baabaaa
bab
bb
bbabbaab
样例输出
1
0
3
0
0


#include <stdio.h>
#include <string.h>
#include <stdlib.h>

int N, M;
char buf[12];
struct  Node {
    Node *next[26];
    int num;
};

Node *CreatNode() {
    Node *p = (Node *)malloc(sizeof(Node));
    p->num = 0;
    memset(p->next, 0, sizeof(p->next));
    return p;
}

void Insert(char *str, Node *p) {
    int id;
    for( ; *str; ++str) {
        id = *str - 'a';
        if(p->next[id] == NULL)
            p->next[id] = CreatNode();
        p = p->next[id];
        ++p->num;
    }
}

int query(char *str, Node *p) {
    int id;
    for( ; *str; ++str) {
        id = *str - 'a';
        p = p->next[id];
        if(p == NULL)
            return 0;
    }
    return p->num;
}

int main() {
    int i, j;   
    Node *root = CreatNode();
    scanf("%d", &N);
    while(N--) {
        scanf("%s", buf);
        Insert(buf, root);
    }
    scanf("%d", &M);
    while(M--) {
        scanf("%s", buf);
        printf("%d\n", query(buf, root));
    }
    return 0;
}


Trie树统计单词前缀

原文:http://blog.csdn.net/chang_mu/article/details/41217419

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!