Description
Input
Output
Sample Input
banana band bee absolute acm ba b band abc
Sample Output
2 3 1 0
题意:我就不说了,你懂的^_^
思路:这是一个简单的字典树模板题
1 struct note//树的定义 2 { 3 note *next[26];//a~z是26,再加A~Z是52,再加0~9是62, 4 int v;//存储这个节点被使用的次数 5 };
1 int ins(char *s)//更新树中的节点 2 { 3 note *p,*q; 4 int len=strlen(s); 5 if(len==0) 6 return 0; 7 p=root; 8 for(int i=0;i<len;i++)//新建节点 9 { 10 int d=s[i]-‘a‘; 11 if(p->next[d]==0) 12 { 13 q=(note *)malloc(sizeof(note)); 14 q->v=1;//新建的节点最开始肯定是被使用过1次的 15 for(int j=0;j<26;j++) 16 q->next[j]=0; 17 p->next[d]=q; 18 p=q; 19 } 20 else//被使用过得节点更新 21 { 22 p=p->next[d]; 23 p->v=p->v+1; 24 } 25 } 26 return 0; 27 }
1 int sea(char *s)//搜索前缀 2 { 3 int len=strlen(s); 4 if(len==0) 5 return 0; 6 note *p,*q; 7 p=root; 8 for(int i=0;i<len;i++) 9 { 10 int d=s[i]-‘a‘; 11 p=p->next[d]; 12 if(p==0) 13 return 0; 14 } 15 return p->v; 16 }
AC代码:
1 #include <iostream> 2 #include <cstdio> 3 #include <cstring> 4 #include <algorithm> 5 #include <cstdlib> 6 using namespace std; 7 struct note//树的定义 8 { 9 note *next[26];//a~z是26,再加A~Z是52,再加0~9是62, 10 int v;//存储这个节点被使用的次数 11 }; 12 struct note *root; 13 int ins(char *s)//更新树中的节点 14 { 15 note *p,*q; 16 int len=strlen(s); 17 if(len==0) 18 return 0; 19 p=root; 20 for(int i=0;i<len;i++)//新建节点 21 { 22 int d=s[i]-‘a‘; 23 if(p->next[d]==0) 24 { 25 q=(note *)malloc(sizeof(note)); 26 q->v=1;//新建的节点最开始肯定是被使用过1次的 27 for(int j=0;j<26;j++) 28 q->next[j]=0; 29 p->next[d]=q; 30 p=q; 31 } 32 else//被使用过得节点更新 33 { 34 p=p->next[d]; 35 p->v=p->v+1; 36 } 37 } 38 return 0; 39 } 40 int sea(char *s)//搜索前缀 41 { 42 int len=strlen(s); 43 if(len==0) 44 return 0; 45 note *p,*q; 46 p=root; 47 for(int i=0;i<len;i++) 48 { 49 int d=s[i]-‘a‘; 50 p=p->next[d]; 51 if(p==0) 52 return 0; 53 } 54 return p->v; 55 } 56 int main() 57 { 58 root=(note *)malloc(sizeof(note)); 59 for(int i=0;i<26;i++) 60 root->next[i]=0; 61 root->v=2; 62 char s[20]; 63 int flag; 64 flag=0; 65 while(gets(s)) 66 { 67 if(strcmp(s,"")==0) 68 { 69 break; 70 } 71 else 72 ins(s); 73 } 74 while(gets(s)) 75 { 76 if(strcmp(s,"")==0) 77 { 78 break; 79 } 80 else 81 printf("%d\n",sea(s)); 82 } 83 return 0; 84 }
原文:http://www.cnblogs.com/wang-ya-wei/p/6057512.html