主页 > 知识库 > PHP实现的字符串匹配算法示例【sunday算法】

PHP实现的字符串匹配算法示例【sunday算法】

热门标签:百度地图标注类型是酒店 400电话申请办理 随州销售电销机器人公司 福建高频外呼防封系统哪家好 商丘外呼系统好处 周口网络回拨外呼系统 全国各省地图标注点 外呼系统人工客服 网络电话400申请

本文实例讲述了PHP实现的字符串匹配算法————sunday算法。分享给大家供大家参考,具体如下:

Sunday算法是Daniel M.Sunday于1990年提出的字符串模式匹配。其核心思想是:在匹配过程中,模式串发现不匹配时,算法能跳过尽可能多的字符以进行下一步的匹配,从而提高了匹配效率。

?php
/*
 *@param $pattern 模式串
 *@param $text 待匹配串
 */
function mySunday($pattern = '',$text = ''){
  if(!$pattern || !$text) return false;
  $pattern_len = mb_strlen($pattern);
  $text_len = mb_strlen($text);
  if($pattern_len >= $text_len) return false;
  $i = 0;
  for($i = 0; $i  $pattern_len; $i++){ //组装以pattern中的字符为下标的数组
    $shift[$pattern[$i]] = $pattern_len - $i;
  }
  while($i = $text_len - $pattern_len){
    $nums = 0;   //匹配上的字符个数
    while($pattern[$nums] == $text[$i + $nums]){
      $nums++;
      if($nums == $pattern_len){
        return "The first match index is $i\n";
      }
    }
    if($i + $pattern_len  $text_len  isset($shift[$text[$i + $pattern_len]])){ //判断模式串后一位字符是否在模式串中
      $i += $shift[$text[$i + $pattern_len]];   //对齐该字符
    }else{
      $i += $pattern_len;   //直接滑动pattern_len位
    }
  }
}
$text = "I am testing mySunday on sunday!";
$pattern = "sunday";
echo mySunday($pattern,$text);

运行结果:

The first match index is 25 

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数据结构与算法教程》、《php程序设计算法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP常用遍历算法与技巧总结》及《PHP数学运算技巧总结》

希望本文所述对大家PHP程序设计有所帮助。

您可能感兴趣的文章:
  • PowerShell中查找字符串位置的IndexOf函数使用实例
  • javascript indexOf函数使用说明
  • Python实现字符串匹配算法代码示例
  • 多模字符串匹配算法原理及Java实现代码
  • Python字符串匹配算法KMP实例
  • php中最简单的字符串匹配算法
  • 浅谈JAVA字符串匹配算法indexOf函数的实现方法

标签:迪庆 定西 佛山 海南 十堰 六安 乐山 南宁

巨人网络通讯声明:本文标题《PHP实现的字符串匹配算法示例【sunday算法】》,本文关键词  PHP,实现,的,字符串,匹配,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《PHP实现的字符串匹配算法示例【sunday算法】》相关的同类信息!
  • 本页收集关于PHP实现的字符串匹配算法示例【sunday算法】的相关信息资讯供网民参考!
  • 推荐文章