http://acm.hdu.edu.cn/showproblem.php?pid=1800
字典树
#include<iostream>
#include<string.h>
#include<stdio.h>
using namespace std;
struct node
{
int sum;
node *next[10];
node()
{
sum=0;
memset(next, NULL, sizeof(next));
};
};
int ans;
char *Delleading0(char *s)
{
while(*s=='0')
s++;
while(*s==0)
s--;
return s;
}
void Buildtiretree(node *head, char *s)
{
node *p=head;
for(int i=0; s[i]; i++)
{
int k=s[i]-'0';
if(p->next[k]==NULL)
p->next[k]=new node();
p=p->next[k];
}
p->sum++;
if(p->sum>ans)
ans=p->sum;
}
int main()
{
char *s, str[35];
int n;
while(scanf("%d", &n)!=EOF)
{
ans=0;
node *head=new node();
//getchar();
while(n--)
{
//gets(str);
scanf("%s", str);
s=Delleading0(str);
Buildtiretree(head, s);
}
printf("%d\n", ans);
}
return 0;
}
本文详细介绍了一种高效的数据结构——字典树的实现方法,并通过一个具体的编程问题展示了其在处理字符串集合上的优势。文章提供了完整的C++代码示例,讲解了如何构建字典树并利用它来解决最大重复子串的问题。
8万+

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



