• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PHP实现的字符串匹配算法示例【sunday算法】

    本文实例讲述了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实现的折半查找算法示例
    下一篇:PHP实现的最大正向匹配算法示例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

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