国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > PHP > 正文

PHP實(shí)現(xiàn)求解最長(zhǎng)公共子串思路方法

2020-03-22 18:53:02
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(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版本

<?phphtml' target='_blank'>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)推薦:

JavaScript自定義函數(shù)實(shí)現(xiàn)查找兩個(gè)字符串最長(zhǎng)公共子串的方法

Python最長(zhǎng)公共子串算法實(shí)例

用PHP求解最長(zhǎng)公共子串問(wèn)題

以上就是PHP實(shí)現(xiàn)求解最長(zhǎng)公共子串思路方法的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注 其它相關(guān)文章!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 镇雄县| 永顺县| 个旧市| 凌云县| 丹凤县| 陇南市| 疏附县| 遂溪县| 铜山县| 察雅县| 大同县| 洛阳市| 德江县| 洛扎县| 大名县| 临泉县| 安仁县| 靖安县| 温州市| 石景山区| 柳河县| 元朗区| 灵宝市| 晋城| 德州市| 精河县| 鸡西市| 来凤县| 策勒县| 昆山市| 孝感市| 米易县| 皋兰县| 衡山县| 镇赉县| 岳池县| 台南县| 乐昌市| 东源县| 唐海县| 资溪县|