码迷,mamicode.com
首页 > 其他好文 > 详细

字典树的实现

时间:2014-10-04 16:16:26      阅读:304      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   os   ar   for   sp   div   2014   


字典树常用于前缀匹配
[syswj@host 0813]$ cat dic_tree.cpp
#include <iostream>
#include <stdio.h>
#define MAX 26
usingnamespace std;
typedefstruct TrieNode
{
    intncount;
    structTrieNode *next[MAX];
}TrieNode;

voidinit(TrieNode **pRoot)//初始化
{
    *pRoot = NULL;
}
 
TrieNode* create()//创建新节点
{
    TrieNode *a =new TrieNode;
    a->ncount = 0;
    for(inti = 0; i < MAX; ++i)
        a->next[i] = NULL;
    returna;
}
 
voidinsert(TrieNode **pRoot, char*s)//插入
{
    inti, k;
    TrieNode *p;
    if(!(p = *pRoot))
    {
        p = *pRoot = create();
    }
    i = 0;
    while(s[i])
    {
        k = s[i++] -'a';
        if(!p->next[k])
        {
            p->next[k] = create();
        }
        p = p->next[k];
    }
    p->ncount++;
}

int search(TrieNode *pRoot, char *s)//查找
{
    TrieNode *p;
    inti, k;
    if(!(p = pRoot))
    {
        return0;
    }
    i = 0;
    while(s[i])
    {
        k = s[i++] -'a';
        if(p->next[k] == NULL)
            return0;
        p = p->next[k];
    }
    returnp->ncount;
}
 
int main(int argc,const char *argv[])
{
  TrieNode *p;
  init(&p);
  chara[20] = {"abc"} ;
  insert(&p, a);
  insert(&p, a);
  insert(&p,"bcd");
  insert(&p,a);
  cout << search(p,a) << endl;
  cout << search(p,"bcd") << endl;
    return0;
}

字典树的实现

标签:style   blog   io   os   ar   for   sp   div   2014   

原文地址:http://blog.csdn.net/aa838260772/article/details/39779065

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!