字典树学习
基本操作
节点声明
const int MAX = 26;
struct Trie
{
Trie * next[MAX];//有多少种类的数
int v;//记录到此处有多少相同的前缀
bool isStr;
Trie()
{
for(int i = 0 ; i < MAX; i++)
next[i] = NULL;
v = 0;
isStr = 0;
}
};
插入
//插入一个新的单词
void insertTrie(Trie*root, const char *s)
{
if(root == NULL || *s == ' ')
return;
Trie* p = root;
while(*s != ' ')
{
//if not exist...
if(p->next[*s-'a'] == NULL)
{
Trie * tmp = new Trie;
p->next[*s-'a'] = tmp;
p = p->next[*s-'a'];
}
//if exist...
else
{
p = p->next[*s-'a'];
}
s++;
}
p->isStr = true;
p->v++;
}
查找
//查找某一字符串
bool searchTrie(char * str)
{
int len = strlen(str);
Trie *p = root;
for(int i = 0 ; i < len ; i++)
{
int id = str[i] - 'a';
p = p->next[id];
if(p == NULL)//not exist
return 0;
}
if(p->isStr == true)
{
cout << "times:" << p->v << endl;
return 1;
}
return 0;
}
删除
//删除空间
void delTrie(Trie * R)
{
if(R == NULL)
return;
for(int i = 0 ; i < MAX ; i++)
{
if(R->next[i] != NULL)
delTrie(R->next[i]);
}
free(R);
return ;
}
完整代码如下:
/*
@theme:字典树学习笔记 - 小写字母26
@writer:pprp
@begin:18:30
@end:
@declare:
*/
#include <iostream>
#include <cstring>
#include <cstdio>
#include <cstdlib>
using namespace std;
const int MAX = 26;
struct Trie
{
Trie * next[MAX];//有多少种类的数
int v;//记录到此处有多少相同的前缀
bool isStr;
Trie()
{
for(int i = 0 ; i < MAX; i++)
next[i] = NULL;
v = 0;
isStr = 0;
}
};
Trie * root = new Trie;
//插入一个新的单词
void insertTrie(Trie*root, const char *s)
{
if(root == NULL || *s == ' ')
return;
Trie* p = root;
while(*s != ' ')
{
//if not exist...
if(p->next[*s-'a'] == NULL)
{
Trie * tmp = new Trie;
p->next[*s-'a'] = tmp;
p = p->next[*s-'a'];
}
//if exist...
else
{
p = p->next[*s-'a'];
}
s++;
}
p->isStr = true;
p->v++;
}
//查找某一字符串
bool searchTrie(char * str)
{
int len = strlen(str);
Trie *p = root;
for(int i = 0 ; i < len ; i++)
{
int id = str[i] - 'a';
p = p->next[id];
if(p == NULL)//not exist
return 0;
}
if(p->isStr == true)
{
cout << "times:" << p->v << endl;
return 1;
}
return 0;
}
//删除空间
void delTrie(Trie * R)
{
if(R == NULL)
return;
for(int i = 0 ; i < MAX ; i++)
{
if(R->next[i] != NULL)
delTrie(R->next[i]);
}
free(R);
return ;
}
int main()
{
freopen("in.txt","r",stdin);
int num;
scanf("%d",&num);
getchar();
char s[1000];
for(int i = 0 ; i < num ; i++)
{
scanf("%s",s);
insertTrie(root,s);
}
int query;
scanf("%d",&query);
getchar();
while(query--)
{
scanf("%s",s);
if(searchTrie(s))
cout << "YES" << endl;
else
cout << "NO" << endl;
}
delTrie(root);
return 0;
}