PHP实现求解最长公共子串问题的方法
发布:smiling 来源: PHP粉丝网 添加日期:2018-09-13 17:46:05 浏览: 评论:0
本文实例讲述了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];
- } //phpfensi.com
- return $str;
- }
- }
- LCS::main();
- ?>
运行结果:
- substring1:cgqtdaacneftabsxvmlb
- substring2:suwjwwakzzhghbsmnksg
- LCS:absm
- Totle time is 0.000648975372314 s
Tags: PHP最长子串 PHP公共子串
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)