PHP實(shí)現(xiàn)求解最長(zhǎng)公共子串問(wèn)題的方法
本文實(shí)例講述了PHP實(shí)現(xiàn)求解最長(zhǎng)公共子串問(wèn)題的方法。分享給大家供大家參考,具體如下:
題目:如果字符串一的所有字符按其在字符串中的順序出現(xiàn)在另外一個(gè)字符串二中,則字符串一稱之為字符串二的子串。
注意,并不要求子串(字符串一)的字符必須連續(xù)出現(xiàn)在字符串二中。即,可以不連續(xù),但順序不能變。
請(qǐng)編寫一個(gè)函數(shù),輸入兩個(gè)字符串,求它們的最長(zhǎng)公共子串,并打印出一個(gè)最長(zhǎng)公共子串。
例如:輸入兩個(gè)字符串BDCABA和ABCBDAB,字符串BCBA和BDAB都是是它們的最長(zhǎng)公共子串,
下面的算法是根據(jù)網(wǎng)上的java算法由酒逍遙 翻譯過(guò)來(lái)的
已經(jīng)經(jīng)過(guò)修正
LCS經(jīng)典算法php版本
<?php
class LCS{
public static function main(){
//設(shè)置字符串長(zhǎng)度
$substringLength1 = 20;
$substringLength2 = 20; //具體大小可自行設(shè)置
$opt=array_fill(0,21,array_fill(0,21,null));
// 隨機(jī)生成字符串
$x = self::GetRandomStrings($substringLength1);
$y = self::GetRandomStrings($substringLength2);
$startTime = microtime(true);
// 動(dòng)態(tài)規(guī)劃計(jì)算所有子問(wèn)題
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();
?>
運(yùn)行結(jié)果:
substring1:cgqtdaacneftabsxvmlb substring2:suwjwwakzzhghbsmnksg LCS:absm Totle time is 0.000648975372314 s
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- php獲取字符串前幾位的實(shí)例(substr返回字符串的子串用法)
- php實(shí)現(xiàn)指定字符串中查找子字符串的方法
- PHP字符串中插入子字符串方法總結(jié)
- php根據(jù)指定位置和長(zhǎng)度獲得子字符串的方法
- PHP中比較兩個(gè)字符串找出第一個(gè)不同字符位置例子
- PHP中substr_count()函數(shù)獲取子字符串出現(xiàn)次數(shù)的方法
- php實(shí)現(xiàn)子字符串位置相互對(duì)調(diào)互換的方法
- php中有關(guān)字符串的4個(gè)函數(shù)substr、strrchr、strstr、ereg介紹和使用例子
- PHP實(shí)現(xiàn)求兩個(gè)字符串最長(zhǎng)公共子串的方法示例
相關(guān)文章
PHP三層結(jié)構(gòu)(上) 簡(jiǎn)單三層結(jié)構(gòu)
我們以一個(gè)簡(jiǎn)單的留言板代碼為例,先來(lái)看一個(gè)最簡(jiǎn)單的三層結(jié)構(gòu)代碼2010-07-07
php通過(guò)記錄IP來(lái)防止表單重復(fù)提交方法分析
這篇文章主要介紹了php通過(guò)記錄IP來(lái)防止表單重復(fù)提交的方法,對(duì)比分析了通過(guò)記錄IP防止重復(fù)提交與通過(guò)數(shù)據(jù)庫(kù)防止重復(fù)提交的方法,供大家靈活選擇與使用,是非常實(shí)用的技巧,需要的朋友可以參考下2014-12-12
php使用array_rand()函數(shù)從數(shù)組中隨機(jī)選擇一個(gè)或多個(gè)元素
這篇文章主要介紹了php使用array_rand()函數(shù)從數(shù)組中隨機(jī)選擇一個(gè)或多個(gè)元素,需要的朋友可以參考下2014-04-04
PHP中new static()與new self()的區(qū)別異同分析
這篇文章主要介紹了PHP中new static()與new self()的區(qū)別異同分析,是很實(shí)用的技巧,需要的朋友可以參考下2014-08-08
PHP對(duì)象的淺復(fù)制與深復(fù)制的實(shí)例詳解
這篇文章主要介紹了PHP對(duì)象的淺復(fù)制與深復(fù)制的實(shí)例詳解的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下2017-10-10

