• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

PHP怎么求解最长公共子串

php 搞代码 3年前 (2022-01-22) 14次浏览 已收录 0个评论

这次给大家带来PHP怎么求解最长公共子串,PHP求解最长公共子串的注意事项有哪些,下面就是实战案例,一起来看一下。

本文实例讲述了PHP实现求解最长公共子串问题的方法。分享给大家供大家参考,具体如下:

题目:如果字符串一的所有字符按其在字符串中的顺序出现在另外一个字符串二中,则字符串一称之为字符串二的子串。

注意,并不要求子串(字符串一)的字符必须连续出现在字符串二中。即,可以不连续,但顺序不能变。

请编写一个函数,输入两个字符串,求它们的最长公共子串,并打印出一个最长公共子串。

例如:输入两个字符串BDCABA和ABCBDAB,字符串BCBA和BDAB都是是它们的最长公共子串,

下面的算法是根据网上的java算法由酒逍遥 翻译过来的

已经经过修正

LCS经典算法php版本

<?phpclass LCS{  public static function main(){    //设置字符串长度    $substringLength1 = 20;    $substringLength2 = 20; //具体大小可自行设置    $opt=array_fill(0,21,array_fill(0,21,null));    // 随机生成字符串    $x = self::GetRandomStrings($substringLength1);    $y = self::GetRandomStrings($substringLength2);    $startTime = microtime(true);    // 动态规划计算所有子问题    for ($i = $substringLength1 - 1; $i >= 0; $i--){      for ($j = $substringLength2 - 1; $j >= 0; $j--){        if ($x[$i] == $y[$j])          $opt[$i][$j] = $opt[$i + 1][$j + 1] + 1;        else          $opt[$i][$j] = max($opt[$i + 1][$j], $opt[$i][$j + 1]);      }    }    echo "substring1:".$x."\r\n";    echo "substring2:".$y."\r\n";    echo "LCS:";    $i = 0;    $j = 0;    while ($i < $substringLength1 && $j < $substringLength2){      if ($x[$i] == $y[$j]){        echo $x[$i];        $i++;        $j++;      } else if ($opt[$i + 1][$j] >= $opt[$i][$j + 1])        $i++;      else        $j++;    }    $endTime = microtime(true);    echo "\r\n";    echo "Totle <strong style="color:transparent">本文来源gao@daima#com搞(%代@#码@网&</strong><strong>搞gaodaima代码</strong>time is " . ($endTime - $startTime) . " s";  }  public static function GetRandomStrings($length){    $buffer = "abcdefghijklmnopqrstuvwxyz";    $str="";    for($i=0;$i<$length;$i++){      $random=rand(0,strlen($buffer)-1);      $str.=$buffer[$random];    }    return $str;  }}LCS::main();?>

运行结果:

substring1:cgqtdaacneftabsxvmlbsubstring2:suwjwwakzzhghbsmnksgLCS:absmTotle time is 0.000648975372314 s

相信看了本文案例你已经掌握了方法,更多精彩请关注搞代码其它相关文章!

推荐阅读:

如何用swoole与websocket开发一个聊天室

PHP有哪些生成随机数的方法

以上就是PHP怎么求解最长公共子串的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:PHP怎么求解最长公共子串

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址