好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PHP實現求解最長公共子串問題的方法

PHP實現求解最長公共子串問題的方法

熱門標簽:商丘外呼系統好處 外呼系統人工客服 400電話申請辦理 全國各省地圖標注點 周口網絡回撥外呼系統 百度地圖標注類型是酒店 網絡電話400申請 福建高頻外呼防封系統哪家好 隨州銷售電銷機器人公司

本文實例講述了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];
    }
    return $str;
  }
}
LCS::main();
?>

運行結果:

substring1:cgqtdaacneftabsxvmlb
substring2:suwjwwakzzhghbsmnksg
LCS:absm
Totle time is 0.000648975372314 s

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP數據結構與算法教程》、《php程序設計算法總結》、《php字符串(string)用法總結》、《PHP數組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結》及《PHP數學運算技巧總結》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • php獲取字符串前幾位的實例(substr返回字符串的子串用法)
  • php實現指定字符串中查找子字符串的方法
  • PHP字符串中插入子字符串方法總結
  • php根據指定位置和長度獲得子字符串的方法
  • PHP中比較兩個字符串找出第一個不同字符位置例子
  • PHP中substr_count()函數獲取子字符串出現次數的方法
  • php實現子字符串位置相互對調互換的方法
  • php中有關字符串的4個函數substr、strrchr、strstr、ereg介紹和使用例子
  • PHP實現求兩個字符串最長公共子串的方法示例

標簽:定西 南寧 迪慶 海南 六安 佛山 十堰 樂山

巨人網絡通訊聲明:本文標題《PHP實現求解最長公共子串問題的方法》,本文關鍵詞  PHP,實現,求解,最長,公共,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP實現求解最長公共子串問題的方法》相關的同類信息!
  • 本頁收集關于PHP實現求解最長公共子串問題的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 黑人与欧洲性大战| 日本女v片| 亚洲一区综合在线播放| 又大又湿又紧又爽A视频在线观看| 出差的交换夫妇中文字幕| 一级做a爰片久久毛片日本| 色妞女女女女女bbbbb1| 粉嫩AV无码一区二区三区水牛 | 国产69精品久久99apgf中文版| 91精品国产高清久久久电影| 中国明星hdxxxx| 大又大又粗又硬又爽少妇毛片| 三级4级全黄60分钟电影| 视频免费观看| 在厨房撕掉岳的丁字裤小说| 九九热爱视频精品99久免费| 永久免费无码AV网站在线观看 | 搡六十70老女人老熟女视频| JIZZJIZZ日本高潮喷水| 欧美 大陆 偷拍 精品| 91人妻精品丰满大屁股干炮| 99自拍视频在线观看| 女的被?到爽羞羞jk视频| 情不自禁高清国语| 四级片在线观看| 丝袜美腿无码| 天天看天天鲁天天爽| 欧美性婬爽www视频播放| 中文字幕网址| 女教师白洁| 51xx午夜影视福利| 韩国免费高清一级毛片性色| 两个男前后夹击高h| 欧美另类在线观看| 在车上伦流澡到高潮Hnp文| 男人的天堂在线观看入口| 特级AAAAAAA片免费看| 国产a做爰全过程片| 一个添下面两个吃奶把腿抬高| 村长撕开乳罩吸奶头| 亚洲精品一区二区无码夜色|