trie(字典树)原理及C++代码实现

字典树,又称前缀树,是用于存储大量字符串或类似数据的数据结构。

它的原理是利用相同前缀来减少查询字符串的时间。

不同于BST把关键字保存在本结点中,TRIE可以想象成把关键字和下一个结点的指针绑定,事实上我也是用map来实现的,所以不熟悉map的提前熟悉map的操作。

Tire的逻辑比较抽象,所以如果是第一次见到这种组织方式的建议先熟悉熟悉这种逻辑再开始写代码,这样会比较顺畅。

代码如下:(仅供参考)

 1 struct Node {
 2 public :
 3     bool isWord;
 4     unordered_map<char, Node*> next;
 5 public :
 6     Node(bool Isword = false) : isWord(Isword) {}
 7 };
 8
 9 class Trie {
10     Node root;
11     int size;
12
13 public :
14     Trie() : size(0) {}
15     int getSize() {return size;}
16     void add(string word);  //添加一个新单词
17     bool contains(string word); //查询是否有该单词
18     bool isPrefix(string prefix); //查询是否有单词以该prefix为前缀
19     void del(string word);  //删除一个单词
20 };
21
22 void Trie::add(string word) {
23     Node *curr = &root;
24
25     for (int i = 0; i < word.length(); ++i) {
26         Node* ptr = nullptr;
27         auto ret = curr->next.insert({word[i], ptr});
28         if (ret.second)
29             ret.first->second = new Node();
30         curr = ret.first->second;
31     }
32
33     if (!curr->isWord) {
34         curr->isWord = true;
35         ++size;
36     }
37 }
38
39 bool Trie::contains(string word) {
40     const Node *curr = &root;
41
42     for (int i = 0; i < word.length(); ++i) {
43         auto ret = curr->next.find(word[i]);
44
45         if (ret == curr->next.end()) {
46             return false;
47         }
48         curr = ret->second;
49     }
50     return curr->isWord;
51 }
52
53 bool Trie::isPrefix(string prefix) {
54     const Node *curr = &root;
55
56     for (int i = 0; i < prefix.length(); ++i) {
57         auto ret = curr->next.find(prefix[i]);
58
59         if (ret == curr->next.end()) {
60             return false;
61         }
62         curr = ret->second;
63     }
64     return true;
65 }
66
67 void Trie::del(string word) {
68     if (!contains(word))
69         return ;
70
71     vector<Node*> preNode;
72     Node *curr = &root;
73
74     for (int i = 0; i < word.length(); ++i) {
75         preNode.push_back(curr);
76         curr = curr->next.find(word[i])->second;
77     }
78     if (curr->next.size() == 0) {
79         for (int i = word.length() - 1; i >= 0 ; --i) {
80             Node *pre = preNode.back();
81             preNode.pop_back();
82
83             if ((i != word.length() - 1) && (curr->isWord || curr->next.size() != 0))
84                 break;
85             delete curr;
86             pre->next.erase(word[i]);
87             curr = pre;
88         }
89     } else {
90         curr->isWord = false;
91     }
92     --size;
93 }

原文地址:https://www.cnblogs.com/yxsrt/p/12249815.html

时间: 2024-11-01 00:06:47

trie(字典树)原理及C++代码实现的相关文章

DFA和trie字典树实现敏感词过滤(python和c语言)

现在做的项目都是用python开发,需要用做关键词检查,过滤关键词,之前用c语言做过这样的事情,用字典树,蛮高效的,内存小,检查快. 到了python上,第一想法是在pip上找一个基于c语言的python字典树模块,可惜没找到合适的,如果我会用c写python模块的话,我就自己写一个了,可惜我还不具备这个能力, 只能用python写了,性能差一点就差点吧,内存多一点也无所谓了. 用搜索引擎看CSDN上的网友的用python实现的DFA,再参照自己以前用c语言写过的字典树,有些不大对,就自己写了一

萌新笔记——C++里创建 Trie字典树(中文词典)(插入、查找、遍历、导入、导出)(上)

写了一个词典,用到了Trie字典树. 写这个词典的目的,一个是为了压缩一些数据,另一个是为了尝试搜索提示,就像在谷歌搜索的时候,打出某个关键字,会提示一串可能要搜索的东西. 首先放上最终的结果: input: 1 编程入门 2 编程软件 3 编程学习 4 编程学习网站 output: 1 char : 件 2 word : 编程软件 3 char : 习 4 word : 编程学习 5 char : 网 6 word : 编程学习网 7 char : 门 8 word : 编程入门 其实这里不应

trie/字典树几题

以后有好多次看到这地方就过去了, 未亲自实践过. 不过今晚看了一下,感觉trie的思想还算是比较基础的. 感觉这一个链接讲的不错:http://www.cnblogs.com/BeyondAnyTime/archive/2012/07/16/2592838.html 顺便水了几道题. 具体列表可见:http://vjudge.net/contest/view.action?cid=47036#overview A:水题啦. 稍微理解下trie就能写出来了. 附个自己写的代码,还是用LRJ书上的非

LeetCode 208.实现Trie(字典树) - JavaScript

??Blog :<LeetCode 208.实现Trie(字典树) - JavaScript> 实现一个 Trie (前缀树),包含 insert, search, 和 startsWith 这三个操作. Trie trie = new Trie(); trie.insert("apple"); trie.search("apple"); // 返回 true trie.search("app"); // 返回 false trie.

Trie 字典树 删除操作

字典树的删除操作: 1 没找到直接返回 2 找到叶子节点的时候,叶子节点的count标志清零,代表不是叶子节点了 3 如果当前节点没有其他孩子节点的时候,可以删除这个节点 判断是否需是叶子节点,就检查叶子节点的count标志就可以了. 判断是否有其他孩子节点就需要循环26个节点了,如果都为空,那么就没有其他孩子节点了. #include <stdio.h> #include <stdlib.h> #include <iostream> #include <vect

Trie字典树 动态内存

Trie字典树 1 #include "stdio.h" 2 #include "iostream" 3 #include "malloc.h" 4 #include "string.h" 5 6 using namespace std; 7 8 #define MAX_SIZE 26 9 10 typedef struct Trie{ 11 char val; 12 bool isword; 13 struct Trie*

算法导论:Trie字典树

1. 概述 Trie树,又称字典树,单词查找树或者前缀树,是一种用于快速检索的多叉树结构,如英文字母的字典树是一个26叉树,数字的字典树是一个10叉树. Trie一词来自retrieve,发音为/tri:/ “tree”,也有人读为/tra?/ “try”. Trie树可以利用字符串的公共前缀来节约存储空间.如下图所示,该trie树用10个节点保存了6个字符串pool.prize.preview.prepare.produce.progress 在该trie树中,字符串preview,prepa

【oiClass1502】查单词(Trie字典树)

题目描述 全国英语四级考试就这样如期来了,可是小y依然没有做好充分准备.为了能够大学毕业,可怜的小y决定作弊.小y费尽心机,在考试的时候夹带了一本字典进考场,但是现在的问题是,考试的时候可能有很多的单词要查,小y能不能来得及呢? 输入 第一行一个整数N,表示字典中一共有多少个单词(N<=10000).接下来每两行表示一个单词,其中:第一行是一个长度<=100的字符串,表示这个单词,全部小写字母,单词不会重复.第二行是一个整数,表示这个单词在字典中的页码.接下来是一个整数M,表示要查的单词数(M

Trie(字典树)解析及其在编程竞赛中的典型应用举例

摘要: 本文主要讲解了Trie的基本思想和原理,实现了几种常见的Trie构造方法,着重讲解Trie在编程竞赛中的一些典型应用. 什么是Trie? 如何构建一个Trie? Trie在编程竞赛中的典型应用有些? 例题解析 什么是Trie? 术语取自retrieval中(检索,收回,挽回)的trie,读作"try",也叫做前缀树或者字典树,是一种有序的树形数据结构.我们常用字典树来保存字符串集合(但不仅限于字符串),如下图就是一个字典树. 它保存的字符集合是{to,te,tea,ted,te

Trie字典树 静态内存

静态字典树 看了好久的字典树,挺简单的一个结构,愣是看了这么久才写出来... 专心一点就不会这样了.... 接下来就去刷刷字典树的题吧....... 下面是字典树.... 定义节点 typedef struct Trie{ char val;  //其实这东西没啥软用...注释掉也一样...没有变化 bool isword; struct Trie *next[26];}*Trie_pointer; 然后建树 这几天抽风了... 把memset写在函数外面去了.... 编译老半天过不去....