主页 > 知识库 > PHP实现求解最长公共子串问题的方法

PHP实现求解最长公共子串问题的方法

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

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

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

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

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

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

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

已经经过修正

LCS经典算法php版本

?php
class 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 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:cgqtdaacneftabsxvmlb
substring2:suwjwwakzzhghbsmnksg
LCS:absm
Totle time is 0.000648975372314 s

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

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

您可能感兴趣的文章:
  • php获取字符串前几位的实例(substr返回字符串的子串用法)
  • php实现指定字符串中查找子字符串的方法
  • PHP字符串中插入子字符串方法总结
  • php根据指定位置和长度获得子字符串的方法
  • PHP中比较两个字符串找出第一个不同字符位置例子
  • PHP中substr_count()函数获取子字符串出现次数的方法
  • php实现子字符串位置相互对调互换的方法
  • php中有关字符串的4个函数substr、strrchr、strstr、ereg介绍和使用例子
  • PHP实现求两个字符串最长公共子串的方法示例

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

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