跳到主要内容

字典树(Trie)

实现

struct Trie
{
int T[N][M],val[N];
int cnt=0;
void init()
{
for(int i=0;i<=cnt;i++)
{
memset(T[i],0,sizeof T[i]);
val[i]=0;
}
cnt=0;
}
void insert(string s)
{
int u=0;
for(auto f:s)
{
int &v=T[u][f];
if(!v)v=++cnt;
u=v;
val[u]++;
}
}
int query(string s)
{
int u=0;
for(auto f:s)
{
int v=T[u][f];
if(!v)return 0;
u=v;
}
return val[u];
}
};

例题

洛谷 P8306 【模板】字典树

#include <bits/stdc++.h>
using namespace std;

const int N=3000005;
const int M=128;
int T[N][M],val[N];
int cnt=0;
void init()
{
for(int i=0;i<=cnt;i++)
{
memset(T[i],0,sizeof T[i]);
val[i]=0;
}
cnt=0;
}
void insert(string s)
{
int u=0;
for(auto f:s)
{
int &v=T[u][f];
if(!v)v=++cnt;
u=v;
val[u]++;
}
}
int query(string s)
{
int u=0;
for(auto f:s)
{
int v=T[u][f];
if(!v)return 0;
u=v;
}
return val[u];
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr);
int T;
cin>>T;
while(T--)
{
int n,q;
cin>>n>>q;
for(int i=1;i<=n;i++)
{
string s;
cin>>s;
insert(s);
}
while(q--)
{
string s;
cin>>s;
cout<<query(s)<<'\n';
}
init();
}
return 0;
}