利用PHP怎么求解最長的公共子串?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
創新互聯公司于2013年創立,先為武侯等服務建站,武侯等地企業,進行企業商務咨詢服務。為武侯企業網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。LCS經典算法php版本
<?php class LCS{ public static function main(){ //設置字符串長度 $substringLength2 = 20; $substringLength3 = 20; //具體大小可自行設置 $opt=array_fill(0,21,array_fill(0,21,null)); // 隨機生成字符串 $x = self::GetRandomStrings($substringLength2); $y = self::GetRandomStrings($substringLength3); $startTime = microtime(true); // 動態規劃計算所有子問題 for ($i = $substringLength2 - 1; $i >= 0; $i--){ for ($j = $substringLength3 - 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 < $substringLength2 && $j < $substringLength3){ 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怎么求解最長的公共子串-創新互聯
轉載來于:http://vcdvsql.cn/article26/cdiijg.html
成都網站建設公司_創新互聯,為您提供移動網站建設、App開發、網站導航、小程序開發、Google、營銷型網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯