首页 > 代码库 > hdu2222Keywords Search字典树入门……
hdu2222Keywords Search字典树入门……
#include<iostream> #include<cstring> using namespace std; struct node { int num; node *next[26]; }*root; void join(const char *s) { node *p=root,*t; int i,len=strlen(s); for(i=0;i<len;i++) if(p->next[s[i]-'a']) p=p->next[s[i]-'a']; else { t=new node; memset(t,0,sizeof(node)); p->next[s[i]-'a']=t; p=t; } p->num++; } void work(const char *s) { node *p; int i,j,len=strlen(s),sum=0; for(i=0;i<len;i++) { p=root; for(j=i;j<len;j++) { if(p->next[s[j]-'a']) { p=p->next[s[j]-'a']; sum+=p->num; p->num=0; } else break; } } printf("%d\n",sum); } void init() { int num; char t[60]; root=new node; memset(root,0,sizeof(node)); scanf("%d",&num); while(num--) { scanf("%s",t); join(t); } } int main() { int exp; char t[1000010]; scanf("%d",&exp); while(exp--) { init(); scanf("%s",t); work(t); } }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。