C++实现敏感词过滤(2) Trie类的实现

三.Trie类的定义

Trie.h:

#include <map>

#include <string>

#include "TrieNode.h"

class Trie {

private:

TrieNode __emptyRoot;

int __pace;

TrieNode* insert(TrieNode* parent, std::string& keyword);

TrieNode* insertBranch(TrieNode* parent, std::string& keyword);

TrieNode* find(TrieNode* parent, std::string& keyword);

std::string toString(TrieNode* parent);

std::string getKeywords(const std::string& character, const TrieNode* parent);

public:

int __size;

Trie(TrieNode::Encoding encoding);

~Trie();

TrieNode* insert(std::string& keyword);

TrieNode* insert(const char* keyword);

TrieNode* find(std::string& keyword);

std::string toString();

std::string getKeywords();

};

inline Trie::~Trie() {

}

说明:

1.__emptyRoot即上面建立的TrieNode树的根节点

2.TrieNode* Trie::find(std::string& keyword)函数即查找是否依次以keyword为单元构建起来的一条分支,比如以helloworld为单元构建起来的分支为h->e->l->l->o->w->o->r->l->d,则查找hello的时候就可以确定hello是敏感词

四.Trie类的实现:

Trie.c

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值