首页 / PHP / PHP 生成 Trie 树
PHP 生成 Trie 树
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了PHP 生成 Trie 树,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含669字,纯文字阅读大概需要1分钟。
内容图文
![PHP 生成 Trie 树](/upload/InfoBanner/zyjiaocheng/718/60f72d13ef0040ee8f9fe9ad5480b68b.jpg)
将所有敏感词生成 Trie 树结构,便于做敏感词检测,生成代码如下
class TrieNode
{
private static $TrieTree;
public function __construct()
{
static::$TrieTree = [];
}
public function insert($sensWords): TrieNode
{
$words = preg_split('//u', $sensWords, -1, PREG_SPLIT_NO_EMPTY);
$_tree = &static::$TrieTree;
foreach ($words as $key => $_word) {
if (!isset($_tree[$_word])) {
$_tree[$_word] = [
'isEnd' => !isset($words[$key + 1]),
'child' => []
];
}
$_tree = &$_tree[$_word]['child'];
}
return $this;
}
public function getTree()
{
return static::$TrieTree;
}
}
$treeNode = (new TrieNode)->insert('CNM')->insert('MLGB')->insert('WRNM')->getTree();
echo json_encode($treeNode,JSON_UNESCAPED_UNICODE);
内容总结
以上是互联网集市为您收集整理的PHP 生成 Trie 树全部内容,希望文章能够帮你解决PHP 生成 Trie 树所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。
来源:【匿名】