首页 > 代码库 > Trie树 模板
Trie树 模板
typedef struct node{ int count; struct node *next[MAX];}Trie;Trie *Newnode()//建立结点&初始化a{ int i; Trie *T; T = (Trie *)malloc(sizeof(Trie)); T->count = 0; for(i=0;i<MAX;i++) T->next[i] = NULL; return T;}
void creatTrie(Trie *root, char *str)//创建{ int i; int len = strlen(str); int id; Trie *p = root; for(i=0;i<len;i++) { id = str[i]-‘a‘; if(p->next[id] == NULL) p->next[id] = Newnode(); p->next[id]->count++; p = p->next[id]; }}
void findTrie(Trie *root, char *str)//查找{ int i; int len = strlen(str); int id; Trie *p = root; for(i=0;i<len;i++) { id = str[i]-‘a‘; if(p->next[id] == NULL) return ; if(p->next[id]->count == 1){ //操作 return ; } if(p->next[id] > 1) //操作 p = p->next[id]; }}
void delTrie(Trie *T)//删除字典树{ int i; for(i=0;i<MAX;i++) if(T->next[i] != NULL) delTrie(T->next[i]); free(T);}
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。