PHP怎麼做出兩個字串的最長公用子串?

來源:互聯網
上載者:User
本文主要給大家做出用PHP求的倆個字串合成最長公用字串的方法。涉及php字串與數組的遍曆、運算、判斷等相關操作技巧。

代碼如下:

<?php$a = 'abceee12345309878';$b = 'abceeew2345i09878fsfsfsfabceeewsfsdfsfsabceeew';$c = array();$lenht1 = strlen($a);$lenth2 = strlen($b);$startTime = microtime(true);for ($i=0;$i<$lenht1;$i++) {  for ($j=0;$j<$lenth2;$j++) {    $n = ($i-1>=0 && $j-1>=0)?$c[$i-1][$j-1]:0;    $n = ($a[$i] == $b[$j]) ? $n+1:0;    $c[$i][$j] = $n;  }}foreach ($c as $key=>$val) {  $max = max($val);  foreach ($val as $key1 =>$val1) {    if ($val1 == $max && $max>0) {      $cdStr[$max] = substr($b,$key1-$max+1,$max);    }  }}ksort($cdStr);$endTime = microtime(true);echo "Totle time is " . ($endTime - $startTime) . " s"."<br/>";print_r(end($cdStr));exit;?>

運行結果:

Totle time is 0.0012800693512 sabceee

相信看了這些案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

相關閱讀:

php自訂函數產生笛卡爾積的方法

PHP如何解決網站大流量與高並發

javascript資料類型和git使用代碼詳解

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.