zoukankan      html  css  js  c++  java
  • Trie树

    Trie树,又名字典树、单词查找树,是一种树形结构,是哈希树的变种。主要用来进行统计、排序、保存大量的字符串。利用字符串的公共前缀减少查询时间,避免了无谓的字符串比较,查询效率比哈希表高,为log(len).

    给出具体的C++实现:

    #include <stdio.h>
    #include <string.h>
    #include <iostream>
    using namespace std;
    
    const int num_chars=26;
    
    class Trie
    {
    public:
        Trie():root(NULL){}
        ~Trie();
        int search(const char* toSearch,char* entry) const;
        int insert(const char* toInsert,const char* entry);
    private:
        struct TrieNode
        {
            char* data;
            TrieNode* branch[num_chars];
            TrieNode();
        };
        TrieNode* root;
    };
    
    Trie::TrieNode::TrieNode()
    {
        data = NULL;
        for(int i=0;i<num_chars;++i)
            branch[i]=NULL;
    }
    
    int Trie::search(const char* toSearch,char* entry) const
    {
        TrieNode* location=root;
        char char_code;
        while(location!=NULL && *toSearch!=0)
        {
            if(*toSearch>='A'&&*toSearch<='Z')
                char_code=*toSearch-'A';
            else if(*toSearch>='a' && *toSearch<='z')
                char_code=*toSearch-'a';
            else
                return 0;
            location=location->branch[char_code];
            ++toSearch;
        }
        if(location!=NULL&& location->data !=NULL)
        {
            strcpy(entry,location->data);
            return 1;
        }
        return 0;
    }
    
    int Trie::insert(const char* toInsert,const char* entry)
    {
        int result=1;
        if(root==NULL)
            root=new TrieNode();
        TrieNode* location=root;
        char char_code;
        while(location!=NULL && *toInsert !=0)
        {
            if(*toInsert>='A'&&*toInsert<='Z')
                char_code=*toInsert-'A';
            else if(*toInsert>='a' && *toInsert<='z')
                char_code=*toInsert-'a';
            else
                return 0;
            if(location->branch[char_code]==NULL)
                location->branch[char_code]=new TrieNode();
            location=location->branch[char_code];
            ++toInsert;
        }
        if(location->data !=NULL)
            result=0;
        else
        {
            location->data=new char[strlen(entry)+1];
            strcpy(location->data,entry);
        }
        return result;
    }
    
    Trie::~Trie()
    {
        if(root!=NULL)
        {
            if(root->data!=NULL)
                    delete  root->data;
            for(int i=0;i<num_chars;++i)
            {
                if(root->branch[i]!=NULL)
                    delete root->branch[i];
            }
            delete root;
        }
        
    }
    int _tmain(int argc, _TCHAR* argv[])
    {
        Trie t;
        char entry[100];
        t.insert("aa", "AA"); 
        t.insert("aab","BB");
        t.insert("aabc","CC"); 
        t.insert("aabbd","DD");
        t.insert("aabbdd","EE"); 
        t.insert("bba","FF");
        t.insert("bbaaa","GG"); 
        t.insert("WANGWEI", "HH");
        if (t.search("WANGWEI", entry))
            cout<<"'WANGWEI' was found. pos: "<<entry<<endl;
        if (t.search("aabbdd", entry))
            cout<<"'aabbdd' is found. pos: "<<entry<<endl;
        if (t.search("gg", entry))
            cout<<"'gg' is found. pos: "<<entry<<endl;
        else
            cout<<"'gg' does not exist at all!"<<endl;
    
        if (t.search("aa", entry))
            cout<<"'aa was found. pos: "<<entry<<endl;
        return 0;
    }
    View Code
  • 相关阅读:
    cocos2dx3.1从零学习(二)菜单、场景切换、场景传值
    XCode5添加新建类模板(Cocos2dx Template Class for Scene or Layer)
    根据Uri获取图片绝对路径,解决Android4.4以上版本Uri转换
    如何学习 cocos2d-x ?
    Java数据类型中String、Integer、int相互间的转换
    Android各种效果集合
    重新生成IE02
    nvl与 is not null的区别等
    自定义view
    select into from 和 insert into select 的用法和区别(转)
  • 原文地址:https://www.cnblogs.com/wwblog/p/3715178.html
Copyright © 2011-2022 走看看