题目链接:
http://acm.hdu.edu.cn/showproblem.php?pid=1251
题解:
字典树模版题
代码:
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define met(a,b) memset(a,b,sizeof(a))
#define inf 0x3f3f3f3f;
const int maxn = 26;
struct Tire
{
Tire *next[maxn];
int cnt;
Tire(){
cnt=0;
for(int i=0;i<maxn;i++)
next[i]=NULL;
}
// 初始化
}root;
char s[maxn];
void create(char *s)
{
int len=strlen(s);
Tire *p=&root;
for(int i=0;i<len;i++)
{
int pos=s[i]-'a';
if(p->next[pos]==NULL)
p->next[pos]=new Tire();
// 如果为空,那么就新建一个
p=p->next[pos];
p->cnt++;
}
}
int search(char *s)
{
int len=strlen(s);
Tire *p=&root;
for(int i=0;i<len;i++)
{
int pos=s[i]-'a';
if(p->next[pos]==NULL)
return 0;
p=p->next[pos];
}
return p->cnt;
}
int main()
{
char s[20];
while(gets(s))
{
if(s[0]==NULL)
break;
create(s);
}
while(gets(s))
{
printf("%d\n",search(s));
}
}
本文介绍了一道经典的字典树模板题目,并提供了详细的代码实现。通过对代码的逐行解析,读者可以了解到如何构建字典树以及如何进行搜索操作。
1038

被折叠的 条评论
为什么被折叠?



