当前位置: 首页 > news >正文

PHP实现DFA算法,查找关键词

# 添加关键词 到全局字典dict里面
protected function addWord($strWord)
{$len = mb_strlen($strWord,'UTF-8');$curNode = &$this->dict;for ($index = 0; $index < $len; $index++) {$word = mb_substr($strWord, $index, 1, 'UTF-8');if (!isset($curNode[$word])) {$curNode[$word] = [];}$curNode =& $curNode[$word];}$curNode['end'] = 1;
}
# 根据字典dict搜索关键词public function searchMatchWords($strWords)
{$len = mb_strlen($strWords, 'UTF-8');$result = [];for ($index = 0; $index < $len; $index++) {$wordLength = $this->searchWord($strWords, $index);if ($wordLength > 0) {$words = mb_substr($strWords, $index, $wordLength, 'UTF-8');if (!isset($result[$words])) {$result[$words] = 1;} else {$result[$words] = $result[$words]++;}$index += $wordLength - 1;}}return $result;
}protected function searchWord($strWords, $beginIndex)
{$len = mb_strlen($strWords, 'UTF-8');$curNode = $this->dict;$isEnd = false;$wordLength = 0;for ($index = $beginIndex; $index < $len; $index++) {$word = mb_substr($strWords, $index, 1, 'UTF-8');if (!isset($curNode[$word])) {break;}$wordLength++;$curNode = $curNode[$word];if (isset($curNode['end'])) {$isEnd = true;}}if (!$isEnd) {$wordLength = 0;}return $wordLength;
}

参考文档

DFA算法匹配关键词 - 简书

http://www.lryc.cn/news/177039.html

相关文章:

  • JTS:08 JTS图形相交
  • 深挖 ThreadLocal 底层原理?它有什么用?学会之后手撕面试官
  • sort()排序函数(c++)
  • 如何评估测试用例的优先级?
  • 510758-28-8,用于标记蛋白质和酶的配体TBTA
  • Jtti:云服务器ftp不能访问端口如何解决
  • 云服务器租用价格表概览_阿里云腾讯云华为云
  • E. Iva Pav -前缀和 + 二分 +位运算
  • 新手学习:ArcGIS对shp文件裁剪
  • Java 设计模式——抽象工厂模式
  • 如何使用ChatGPT构建一个Web应用程序?
  • 关闭手机广告的步骤
  • 【Verilog 教程】6.6Verilog 仿真激励
  • Win/Mac版Scitools Understand教育版申请
  • 第十四届蓝桥杯大赛软件赛决赛 C/C++ 大学 B 组 试题 C: 班级活动
  • YOLOv8改进新颖的Gather-and-Distribute机制,低阶高阶新颖融合,增强了多尺度特征融合能力,实现了延迟和准确性的理想平衡
  • 面试算法13:二维子矩阵的数字之和
  • Vue安装插件时候中遇到冲突依赖解决方案
  • realloc函数应用IO泄露体验
  • (c语言)野指针
  • 【Git】轻松学会 Git(一):掌握 Git 的基本操作
  • rust trait对象
  • Linux学习第21天:Linux内核定时器驱动开发: 流淌的时间长河
  • Centos服务在服务器重启后自启
  • 慢性疼痛治疗服务公司Kindly MD申请700万美元纳斯达克IPO上市
  • 代码随想录 Day6 哈希 LeetcodeT454 四数之和II T383赎金信 T15 三数之和 T18 四数之和
  • 干货速来|教你如何撰写毕业论文
  • 【ROS 2】-2 话题通信
  • Unity之NetCode多人网络游戏联机对战教程(2)--简单实现联机
  • makdown文法