zoukankan      html  css  js  c++  java
  • 字典树

    字典树学习

    基本操作

    节点声明

    const int MAX = 26;
    struct Trie
    {
        Trie * next[MAX];//有多少种类的数
        int v;//记录到此处有多少相同的前缀
        bool isStr;
        Trie()
        {
            for(int i = 0 ; i < MAX; i++)
                next[i] = NULL;
            v = 0;
            isStr = 0;
        }
    };
    

    插入

    //插入一个新的单词
    void insertTrie(Trie*root, const char *s)
    {
        if(root == NULL || *s == '')
            return;
        Trie* p = root;
        while(*s != '')
        {
            //if not exist...
            if(p->next[*s-'a'] == NULL)
            {
                Trie * tmp = new Trie;
                p->next[*s-'a'] = tmp;
                p = p->next[*s-'a'];
            }
            //if exist...
            else
            {
                p = p->next[*s-'a'];
            }
            s++;
        }
        p->isStr = true;
        p->v++;
    }
    

    查找

    //查找某一字符串
    bool searchTrie(char * str)
    {
        int len = strlen(str);
        Trie *p = root;
        for(int i = 0 ; i < len ; i++)
        {
            int id = str[i] - 'a';
            p = p->next[id];
            if(p == NULL)//not exist
                return 0;
        }
        if(p->isStr == true)
        {
            cout << "times:" << p->v << endl;
            return 1;
        }
        return 0;
    }
    

    删除

    //删除空间
    void delTrie(Trie * R)
    {
        if(R == NULL)
            return;
        for(int i = 0 ; i < MAX ; i++)
        {
            if(R->next[i] != NULL)
                delTrie(R->next[i]);
        }
        free(R);
        return ;
    }
    

    完整代码如下:

    /*
    @theme:字典树学习笔记 - 小写字母26
    @writer:pprp
    @begin:18:30
    @end:
    @declare:
    */
    
    #include <iostream>
    #include <cstring>
    #include <cstdio>
    #include <cstdlib>
    
    using namespace std;
    const int MAX = 26;
    struct Trie
    {
        Trie * next[MAX];//有多少种类的数
        int v;//记录到此处有多少相同的前缀
        bool isStr;
        Trie()
        {
            for(int i = 0 ; i < MAX; i++)
                next[i] = NULL;
            v = 0;
            isStr = 0;
        }
    };
    
    Trie * root = new Trie;
    
    //插入一个新的单词
    void insertTrie(Trie*root, const char *s)
    {
        if(root == NULL || *s == '')
            return;
        Trie* p = root;
        while(*s != '')
        {
            //if not exist...
            if(p->next[*s-'a'] == NULL)
            {
                Trie * tmp = new Trie;
                p->next[*s-'a'] = tmp;
                p = p->next[*s-'a'];
            }
            //if exist...
            else
            {
                p = p->next[*s-'a'];
            }
            s++;
        }
        p->isStr = true;
        p->v++;
    }
    
    //查找某一字符串
    bool searchTrie(char * str)
    {
        int len = strlen(str);
        Trie *p = root;
        for(int i = 0 ; i < len ; i++)
        {
            int id = str[i] - 'a';
            p = p->next[id];
            if(p == NULL)//not exist
                return 0;
        }
        if(p->isStr == true)
        {
            cout << "times:" << p->v << endl;
            return 1;
        }
        return 0;
    }
    
    //删除空间
    void delTrie(Trie * R)
    {
        if(R == NULL)
            return;
        for(int i = 0 ; i < MAX ; i++)
        {
            if(R->next[i] != NULL)
                delTrie(R->next[i]);
        }
        free(R);
        return ;
    }
    
    int main()
    {
        freopen("in.txt","r",stdin);
        int num;
        scanf("%d",&num);
        getchar();
        char s[1000];
        for(int i = 0 ; i < num ; i++)
        {
            scanf("%s",s);
            insertTrie(root,s);
        }
        int query;
        scanf("%d",&query);
        getchar();
        while(query--)
        {
            scanf("%s",s);
            if(searchTrie(s))
                cout << "YES" << endl;
            else
                cout << "NO" << endl;
        }
    
        delTrie(root);
        return 0;
    }
    
    
  • 相关阅读:
    教你怎么叠T恤
    最动人的情歌《The Power of Love》by Celine.Dion
    使代码简洁的 5 条忠告
    Timeout MessageBox
    内联函数
    局部对象
    const用法(转)
    心情
    内联函数
    局部对象
  • 原文地址:https://www.cnblogs.com/pprp/p/7657842.html
Copyright © 2011-2022 走看看