码迷,mamicode.com
首页 > 编程语言 > 详细

字典树(数组 查找前缀)

时间:2018-05-27 10:47:47      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:字典   class   div   查找   oid   har   出现   root   字母   

int trie[400001][26],len,root,tot,sum[400001];
bool p;
int n,m; 
char s[11];
void insert()
{
    len=strlen(s);
    root=0;
    for(int i=0;i<len;i++)
    {
        int id=s[i]-a;
        if(!trie[root][id]) trie[root][id]=++tot;
        sum[trie[root][id]]++;//前缀后移一个位置保存 
        root=trie[root][id];
    }
}
int search()
{
    root=0;
    len=strlen(s);
    for(int i=0;i<len;i++)
    {
        int id=s[i]-a;
        if(!trie[root][id]) return 0;
        root=trie[root][id];
    }//root经过此循环后变成前缀最后一个字母所在位置的后一个位置 
    return sum[root];//因为前缀后移了一个保存,所以此时的sum[root]就是要求的前缀出现的次数 
}

 

字典树(数组 查找前缀)

标签:字典   class   div   查找   oid   har   出现   root   字母   

原文地址:https://www.cnblogs.com/ww123/p/9095100.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!