加载中...

Trie 树

Trie 树, 高效地存储和查找字符串集合的数据结构


//Trie树模板
int son[N][26],cnt[N],idx;

//插入一个字符串
void insert (char str[])
{
    int p=0;
    for(int i=0;str[i];i++)
    {
        int u=str[i]-'a';
        if(!son[p][u])son[p][u]=++idx;
        p=son[p][u];
    }
    cnt[p]++;
}

//查询字符串出现的次数
int query (char str[])
{
    int p=0;
    for(int i=0;str[i];i++)
    {
        int u=str[i]-'a';
        if(!son[p][u])return 0;
        p=son[p][u];
    }
    return cnt[p];
}


posted @ 2023-04-29 17:57  邪童  阅读(7)  评论(0编辑  收藏  举报