Trie字典树算法

一、Trie(字典树)概念

Trie(字典树)是一种用于实现字符串快速检索的多叉树结构。Trie 的每个节点都拥有若干个字符指针,若在插入或检索字符串时扫描到一个字符 c,就沿着当前节点的c字符指针,走向该指针指向的节点。

二、Trie的实现原理

在一棵空Trie上插入相应的字符串,字符数据都体现在数的边(指针)上, 树的节点进保存了一些额外信息,比如字符串的结尾。该算法的时间复杂度为O(NC),其中N是节点个数,C是字符集的大小。 然后我们将Trie树存入Trie[SIZE][N]数组中,SIZE表示当前字符串的位置(节点),也可以看作深度,N是当前节点的度,也就是当前节点的孩子个数。在Trie数组声明时,要按照存储的字符串类型进行存储。例如:

存十进制数组:N = 10,表示每个节点最多有10个孩子,分别是0 - 10;
存字符串:N = 26, 表示每个节点最多有26个孩子,分别是 a - z;

同时, 当我们存字符串时,我们可以按照将字母转换为ASCII码进行存储。

三、Trie的C++实现方式

int Trie[SIZE][26], tot = 1;	//初始化,假设字符串由小写字母构成
void insert(string s) {
	int  p = 1;
	for(int k = 0; k < s.size(); k ++ ){
		int ch = s[k] - 'a';
		if (Trie[p][ch] == 0) Trie[p][ch] = ++tot;
		p = Trie[p][ch];
	}
	end[p] = true;
}
bool search(string s) {
	int p = 1;
	for(int k = 0; k < s.size(); k ++ ) {
		p = Trie[p][s[i] - 'a'];
		if(p == 0) return false;
	}
	return end[p];
}

四、关于Trie的练习例题

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值