欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用C++實現(xiàn)最長公共子序列與最長公共子串

 更新時間:2016年12月12日 11:00:40   作者:Treant  
這篇文章主要給大家介紹了如何利用C++實現(xiàn)最長公共子序列與最長公共子串,文章一開始就給大家簡單的介紹了什么是子序列,子串應該比較好理解就不用多介紹了,人后通過算法及示例代碼詳細介紹了C++實現(xiàn)的方法,有需要的朋友們可以參考借鑒,下面來一起看看吧。

一、問題描述

子串應該比較好理解,至于什么是子序列,這里給出一個例子:有兩個母串

cnblogs

belong

比如序列bo, bg, lg在母串cnblogs與belong中都出現(xiàn)過并且出現(xiàn)順序與母串保持一致,我們將其稱為公共子序列。最長公共子序列(Longest Common Subsequence, LCS),顧名思義,是指在所有的子序列中最長的那一個。子串是要求更嚴格的一種子序列,要求在母串中連續(xù)地出現(xiàn)。在上述例子的中,最長公共子序列為blog(cnblogs, belong),最長公共子串為lo(cnblogs, belong)。

二、求解算法

對于母串X=<x1,x2,⋯,xm>X=<x1,x2,⋯,xm>, Y=<y1,y2,⋯,yn>Y=<y1,y2,⋯,yn> ,求LCS與最長公共子串。

暴力解法

假設 m<nm<n, 對于母串XX,我們可以暴力找出2m2m個子序列,然后依次在母串YY中匹配,算法的時間復雜度會達到指數(shù)級O(n∗2m)O(n∗2m) 。顯然,暴力求解不太適用于此類問題。

動態(tài)規(guī)劃

假設Z=<z1,z2,⋯,zk>Z=<z1,z2,⋯,zk>是XX與YY的LCS, 我們觀察到

     如果xm=ynxm=yn,則zk=xm=ynzk=xm=yn,有Zk−1Zk−1是Xm−1Xm−1與Yn−1Yn−1的LCS;

     如果xm≠ynxm≠yn,則ZkZk是XmXm與Yn−1Yn−1的LCS,或者是Xm−1Xm−1與YnYn的LCS。

因此,求解LCS的問題則變成遞歸求解的兩個子問題。但是,上述的遞歸求解的辦法中,重復的子問題多,效率低下。改進的辦法——用空間換時間,用數(shù)組保存中間狀態(tài),方便后面的計算。這就是動態(tài)規(guī)劃(DP)的核心思想了。

DP 求解 LCS

用二維數(shù)組c[i][j]記錄串x1x2⋯xix1x2⋯xi與y1y2⋯yjy1y2⋯yj的LCS長度,則可得到狀態(tài)轉移方程

代碼實現(xiàn)

public static int lcs(String str1, String str2) {
 int len1 = str1.length();
 int len2 = str2.length();
 int c[][] = new int[len1+1][len2+1];
 for (int i = 0; i <= len1; i++) {
 for( int j = 0; j <= len2; j++) {
  if(i == 0 || j == 0) {
  c[i][j] = 0;
  } else if (str1.charAt(i-1) == str2.charAt(j-1)) {
  c[i][j] = c[i-1][j-1] + 1;
  } else {
  c[i][j] = max(c[i - 1][j], c[i][j - 1]);
  }
 }
 }
 return c[len1][len2];
}

DP 求解最長公共子串

前面提到了子串是一種特殊的子序列,因此同樣可以用DP來解決。定義數(shù)組的存儲含義對于后面推導轉移方程顯得尤為重要,糟糕的數(shù)組定義會導致異常繁雜的轉移方程。考慮到子串的連續(xù)性,將二維數(shù)組c[i][j]用來記錄具有這樣特點的子串——結尾同時也為為串x1x2⋯xix1x2⋯xi與y1y2⋯yjy1y2⋯yj的結尾——的長度。

得到轉移方程:

最長公共子串的長度為 max(c[i,j]), i∈{1,⋯,m},j∈{1,⋯,n}max(c[i,j]), i∈{1,⋯,m},j∈{1,⋯,n} 。

代碼實現(xiàn)

public static int lcs(String str1, String str2) {
 int len1 = str1.length();
 int len2 = str2.length();
 int result = 0; //記錄最長公共子串長度
 int c[][] = new int[len1+1][len2+1];
 for (int i = 0; i <= len1; i++) {
 for( int j = 0; j <= len2; j++) {
  if(i == 0 || j == 0) {
  c[i][j] = 0;
  } else if (str1.charAt(i-1) == str2.charAt(j-1)) {
  c[i][j] = c[i-1][j-1] + 1;
  result = max(c[i][j], result);
  } else {
  c[i][j] = 0;
  }
 }
 }
 return result;
}

總結

以上就是這篇文章的全部內(nèi)容改了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

相關文章

  • C++精要分析decltype的作用及用法

    C++精要分析decltype的作用及用法

    decltype是C++11新增的一個關鍵字,和auto的功能一樣,用來在編譯時期進行自動類型推導。引入decltype是因為auto并不適用于所有的自動類型推導場景,在某些特殊情況下auto用起來很不方便,甚至壓根無法使用
    2022-05-05
  • C語言共用體union作用使用示例教程

    C語言共用體union作用使用示例教程

    這篇文章主要為大家介紹了C語言共用體union作用的使用示例教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-02-02
  • 關于C++中strcpy函數(shù)例題講解

    關于C++中strcpy函數(shù)例題講解

    在本篇文章里小編給大家整理的是關于C++中strcpy函數(shù)例題講解內(nèi)容,需要的朋友們可以參考下。
    2020-05-05
  • Opencv基于文字檢測去圖片水印的實現(xiàn)示例

    Opencv基于文字檢測去圖片水印的實現(xiàn)示例

    去水印是個麻煩事,本文就來介紹一種方法Opencv基于文字檢測去圖片水印的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • C語言繪制三角函數(shù)曲線

    C語言繪制三角函數(shù)曲線

    這篇文章主要為大家詳細介紹了C語言繪制三角函數(shù)曲線,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • C++?protobuf中對不同消息內(nèi)容進行賦值的方式總結(set_、set_allocated_、mutable_、add_)

    C++?protobuf中對不同消息內(nèi)容進行賦值的方式總結(set_、set_allocated_、mutable_、

    這篇文章主要給大家介紹了關于C++?protobuf中對不同消息內(nèi)容進行賦值的方式總結,主要使用的是set_、set_allocated_、mutable_、add_,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-03-03
  • C++未定義行為(undefined behavior)

    C++未定義行為(undefined behavior)

    對于未定義行為,C++標準沒有明確規(guī)定編譯器們應該怎么做,那么執(zhí)行的結果就是不可預料的。下面我們來詳細探討下
    2017-02-02
  • C語言設計一個閃閃的圣誕樹

    C語言設計一個閃閃的圣誕樹

    本文使用C語言基礎知識在控制臺打印一個圣誕樹效果,真的很簡單哦,一起通過本文學習吧
    2016-12-12
  • C++將模板實現(xiàn)放入頭文件原理解析

    C++將模板實現(xiàn)放入頭文件原理解析

    這篇文章主要為大家介紹了C++將模板實現(xiàn)放入頭文件原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • 基于C++泛型編程職工管理系統(tǒng)

    基于C++泛型編程職工管理系統(tǒng)

    這篇文章主要介紹了基于C++泛型編程職工管理系統(tǒng),前面介紹到了C++的泛型編程,并實現(xiàn)了萬能容器,不過那使用的是數(shù)組,今天呢咱帶大家實踐一下使用泛型技術,結合單鏈表實現(xiàn)一個職工管理系統(tǒng),需要的朋友可以參考一下
    2022-02-02

最新評論