国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【動態(tài)規(guī)劃】最長公共子序列——算法設(shè)計與分析

這篇具有很好參考價值的文章主要介紹了【動態(tài)規(guī)劃】最長公共子序列——算法設(shè)計與分析。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。


一、問題定義

1.1 子序列

子序列是給定序列中在任意位置去掉任意多個字符后得到的結(jié)果。例如:

給定序列 X X X

X : A B C B D A B X:ABCBDAB XABCBDAB

X X X的子序列:

X 1 : A B C B D A B X_1:ABCBDAB X1?ABCBDAB

X 2 : A B C B X_2:ABCB X2?ABCB

X 3 : A C B B X_3:ACBB X3?ACBB


1.2 公共子序列

給定兩個序列 X X X Y Y Y

X : A B C B D A B X:ABCBDAB XABCBDAB

Y : B D C A B A Y:BDCABA YBDCABA

公共子序列示例:

X 1 = Y 1 = C A X_1=Y_1=CA X1?=Y1?=CA

X 2 = Y 2 = A B A X_2=Y_2=ABA X2?=Y2?=ABA

X 3 = Y 3 = B C A B X_3=Y_3=BCAB X3?=Y3?=BCAB


1.3 問題形式化定義

最長公共子序列問題:

輸入:

\quad 序列 X = < x 1 , x 2 , . . . , x n > X=<x_1,x_2,...,x_n> X=<x1?,x2?,...,xn?>和序列 Y = < y 1 , y 2 , . . . , y m > Y=<y_1,y_2,...,y_m> Y=<y1?,y2?,...,ym?>

輸出:

\quad 求解一個公共子序列 Z = < z 1 , z 2 , . . . , z l > Z=<z_1,z_2,...,z_l> Z=<z1?,z2?,...,zl?>

\quad \quad \quad 優(yōu)化目標(biāo): m a x ∣ Z ∣ max|Z| maxZ

\quad \quad \quad 約束條件: < z 1 , z 2 , . . . , z l > = < x i 1 , x i 2 , . . . , x l 1 > = < y j 1 , y j 2 , . . . , y j l > <z_1,z_2,...,z_l>=<x_{i_1},x_{i_2},...,x_{l_1}>=<y_{j_1},y_{j_2},...,y _{j_l}> <z1?,z2?,...,zl?>=<xi1??,xi2??,...,xl1??>=<yj1??,yj2??,...,yjl??>,其中 1 ≤ i 1 < i 2 < . . . < i l ≤ n ; 1 ≤ j 1 < j 2 < . . . < j l ≤ m 1\leq i_1< i_2<...<i_l\leq n;1\leq j_1<j_2<...<j_l\leq m 1i1?<i2?<...<il?n;1j1?<j2?<...<jl?m



二、求解策略

給定兩個序列 X X X Y Y Y

X : A B C B D A B X:ABCBDAB XABCBDAB

Y : B D C A B A Y:BDCABA YBDCABA

其最長公共子序列 Z = B D A B Z=BDAB Z=BDAB,觀察可以發(fā)現(xiàn),其后3位為長度為3的最長公共子序列,其后2位為長度為2的最長公共子序列,最后一位為長度為一的最長公共子序列。這便啟示我們可能存在最優(yōu)子結(jié)構(gòu)和重疊子問題,可以采用動態(tài)規(guī)劃進(jìn)行求解。


2.1 分析問題結(jié)構(gòu)

形式化給出問題表示:

  • C [ i , j ] C[i,j] C[i,j] X [ 1.. i ] X[1..i] X[1..i] Y [ 1.. j ] Y[1..j] Y[1..j]的最長公共子序列長度

明確原始問題:

  • C [ n , m ] C[n,m] C[n,m] X [ 1.. n ] X[1..n] X[1..n] Y [ 1.. m ] Y[1..m] Y[1..m]的最長公共子序列長度

2.2 建立遞推關(guān)系

對于給定序列:

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃

對于末尾來說,有兩種情況:

x i = y j x_i=y_j xi?=yj?

此時,
C [ i , j ] = m a x { C [ i ? 1 , j ? 1 ] + 1 ① C [ i ? 1 , j ] ② C [ i , j ? 1 ] ③ C[i,j]=max\left\{\begin{matrix} C[i-1,j-1]+1 & ①\\ C[i-1,j] & ②\\ C[i,j-1] &③ \end{matrix}\right. C[i,j]=max? ? ??C[i?1,j?1]+1C[i?1,j]C[i,j?1]??
但是, ① ≥ m a x { ②,③ } {①\ge max\left \{ ②,③ \right \} } max{,},因此,
C [ i , j ] = C [ i ? 1 , j ? 1 ] + 1 C[i,j]=C[i-1,j-1]+1 C[i,j]=C[i?1,j?1]+1

x i ≠ y j x_i \ne y_j xi?=yj?

此時,
C [ i , j ] = m a x { C [ i ? 1 , j ] ① C [ i , j ? 1 ] ② C[i,j]=max\left\{\begin{matrix} C[i-1,j] & ①\\ C[i,j-1] & ② \end{matrix}\right. C[i,j]=max{C[i?1,j]C[i,j?1]??
綜上所述,得到遞推關(guān)系式:
C [ i , j ] = { C [ i ? 1 , j ? 1 ] + 1 x i = y j m a x { C [ i ? 1 , j ] , C [ i , j ? 1 ] } x i ≠ y j C[i,j]=\left\{\begin{matrix} C[i-1,j-1]+1 & x_i=y_j\\ max\left\{ C[i-1,j],\\ C[i,j-1] \right\} & x_i\ne y_j\\ \end{matrix}\right. C[i,j]={C[i?1,j?1]+1max{C[i?1,j],C[i,j?1]}?xi?=yj?xi?=yj??

2.3 自底向上計算

(1)初始化

當(dāng)其中一段序列長度為0時,最長公共子序列長度為0,即: C [ i , 0 ] = C [ 0 , j ] = 0 C[i,0]=C[0,j]=0 C[i,0]=C[0,j]=0

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃

(2)依照遞推公式計算

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃


2.4 追蹤最優(yōu)方案

構(gòu)造追蹤數(shù)組 r e c [ 1.. n ] rec[1..n] rec[1..n],用來記錄子問題的來源:
r e c [ i , j ] = { L U i f C [ i , j ] = C [ i ? 1 , j ? 1 ] + 1 U i f C [ i , j ] = C [ i ? 1 , j ] L i f C [ i , j ] = C [ i , j ? 1 ] rec[i,j]=\left\{\begin{matrix} LU & if\quad C[i,j]=C[i-1,j-1]+1\\ U & if\quad C[i,j]=C[i-1,j]\\ L & if\quad C[i,j]=C[i,j-1] \end{matrix}\right. rec[i,j]=? ? ??LUUL?ifC[i,j]=C[i?1,j?1]+1ifC[i,j]=C[i?1,j]ifC[i,j]=C[i,j?1]?
(使用 U U U代表來自上方, L L L代表來自左方, L U LU LU代表來自左上角)

當(dāng)左值和上值相等時,任取其一即可。

從右下角開始追蹤,如果其值為 L L L,則向左移動1格, U U U則向上移動一格, L U LU LU向左上角移動一格。當(dāng)且僅當(dāng) r e c [ i , j ] = L U rec[i,j]=LU rec[i,j]=LU時, X [ i ] = Y [ j ] X[i]=Y[j] X[i]=Y[j]為最長公共子序列中的一個字符,記錄下來。如此尋找,直至抵達(dá) r e c rec rec數(shù)組的邊界。


2.5 算法實例

給定序列 X X X Y Y Y

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃

初始化輔助數(shù)組:

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃

計算完畢:

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃

追蹤最優(yōu)方案:

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃

得到最長公共子序列 B C B A BCBA BCBA



三、算法分析

3.1 偽代碼

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃

最長公共子序列動態(tài)規(guī)劃算法,算法設(shè)計與分析,動態(tài)規(guī)劃,算法,動態(tài)規(guī)劃


3.2 時間復(fù)雜度

時間復(fù)雜度 O ( n m ) O(nm) O(nm)文章來源地址http://www.zghlxwxcb.cn/news/detail-743439.html

到了這里,關(guān)于【動態(tài)規(guī)劃】最長公共子序列——算法設(shè)計與分析的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • (Java) 算法——動態(tài)規(guī)劃 最長公共子序列 圖解

    (Java) 算法——動態(tài)規(guī)劃 最長公共子序列 圖解

    遇到了用動態(tài)規(guī)劃來求解最長公共子序列問題,算法這塊兒比較薄弱,便想著在網(wǎng)上找現(xiàn)成的思路和代碼,也算拾人牙慧,但有一點沒想到,都已經(jīng)22年了,關(guān)于LCS問題網(wǎng)上給出的答案如此一言難盡……,只有零散幾篇對于 新手 來說比較友好,但也僅僅這樣,好在自己花了點

    2023年04月08日
    瀏覽(21)
  • 【算法(四·三):動態(tài)規(guī)劃思想——最長公共子序列問題】

    【算法(四·三):動態(tài)規(guī)劃思想——最長公共子序列問題】

    最長公共子序列(Longest Common Subsequence,簡稱LCS)問題是一種常見的字符串處理問題。它的**目標(biāo)是找到兩個或多個字符串中的最長公共子序列,這個子序列不需要是連續(xù)的,但字符在原始字符串中的相對順序必須保持一致。**例如,考慮兩個字符串\\\"ABCD\\\"和\\\"ACDF\\\",它們的最長公

    2024年04月13日
    瀏覽(19)
  • 【算法】力扣【動態(tài)規(guī)劃,LCS】1143. 最長公共子序列

    1143. 最長公共子序列 本文是對 LCS 這一 動態(tài)規(guī)劃 模型的整理,以力扣平臺上的算法題1143:最長公共子序列為模板題進(jìn)行解析。 該題目要求計算兩個字符串的最長公共子序列(Longest Common Subsequence,簡稱LCS)的長度。字符串的子序列是指在不改變字符順序的情況下,通過刪去

    2024年01月17日
    瀏覽(27)
  • 【算法設(shè)計與分析】(三)動態(tài)規(guī)劃_更新中:斐波那契、二項式系數(shù)、樹的最大獨立集、最長遞增、公共子序列、編輯距離、Hischberg、最優(yōu)二叉搜索樹、交替拿硬幣、石子合并、背包、乘電梯

    【算法設(shè)計與分析】(三)動態(tài)規(guī)劃_更新中:斐波那契、二項式系數(shù)、樹的最大獨立集、最長遞增、公共子序列、編輯距離、Hischberg、最優(yōu)二叉搜索樹、交替拿硬幣、石子合并、背包、乘電梯

    分治 動態(tài)規(guī)劃本篇 還差一堆 貪心 網(wǎng)絡(luò)流 首先,怕誤人子弟必須聲明一下 本人很菜 (越復(fù)習(xí)越覺得完蛋了 作為一個科班研究生算法學(xué)成這樣非常慚愧(跪 ,可能寫的都不是很懂,很多內(nèi)容打算背過去了。因為我發(fā)現(xiàn)好像真的有人看所以多提醒一句。。(大家就只食用目錄

    2024年01月19日
    瀏覽(25)
  • 算法套路十五——動態(tài)規(guī)劃求解最長公共子序列LCS

    算法套路十五——動態(tài)規(guī)劃求解最長公共子序列LCS

    給定兩個字符串 text1 和 text2,返回這兩個字符串的最長 公共子序列 的長度。如果不存在 公共子序列 ,返回 0 。 一個字符串的 子序列 是指這樣一個新的字符串:它是由原字符串在不改變字符的相對順序的情況下刪除某些字符(也可以不刪除任何字符)后組成的新字符串。

    2024年02月04日
    瀏覽(23)
  • python數(shù)據(jù)結(jié)構(gòu)與算法-動態(tài)規(guī)劃(最長公共子序列)

    python數(shù)據(jù)結(jié)構(gòu)與算法-動態(tài)規(guī)劃(最長公共子序列)

    一個序列的子序列是在該序列中刪去若干元素后得 到的序列。 例如:\\\"ABCD”和“BDF”都是“ABCDEFG”的子序列。 最長公共子序列(LCS) 問題: 給定兩個序列X和Y,求X和Y長度最大的公共子字列。 例:X=\\\"ABBCBDE”Y=\\\"DBBCDB”LCS(XY)=\\\"BBCD\\\" 應(yīng)用場景:字符串相似度比對 (1)問題思考 思考: 暴

    2024年02月08日
    瀏覽(28)
  • 9.動態(tài)規(guī)劃——4.最長公共子序列(動態(tài)規(guī)劃類的算法題該如何解決?)

    9.動態(tài)規(guī)劃——4.最長公共子序列(動態(tài)規(guī)劃類的算法題該如何解決?)

    設(shè)最長公共子序列 d p [ i ] [ j ] dp[i][j] d p [ i ] [ j ] 是 S 1 S_1 S 1 ? 的前 i i i 個元素,是 S 2 S_2 S 2 ? 的前 j j j 個元素,那么有: 若 S 1 [ i ? 1 ] = = S 2 [ i ? 1 ] S_1[i-1]==S_2[i-1] S 1 ? [ i ? 1 ] == S 2 ? [ i ? 1 ] ,那么 d p [ i ] [ j ] = d p [ i ? 1 ] [ j ? 1 ] + 1 dp[i][j]=dp[i-1][j-1]+1 d p [

    2024年04月11日
    瀏覽(23)
  • 算法 DAY52 動態(tài)規(guī)劃10 1143.最長公共子序列 1035.不相交的線 53. 最大子數(shù)組和

    本題和動態(tài)規(guī)劃:718. 最長重復(fù)子數(shù)組 (opens new window)區(qū)別在于這里不要求是連續(xù)的了 1、dp數(shù)組 dp[i][j]:長度為[0, i - 1]的字符串text1與長度為[0, j - 1]的字符串text2的最長公共子序列為dp[i][j] 2、遞推公式 因為不強(qiáng)調(diào)是連續(xù)的,當(dāng)前dp[i][j] 就有三種路徑可以選:dp[i-1][j] dp[i][j-1]

    2024年02月03日
    瀏覽(34)
  • 動態(tài)規(guī)劃--最長公共子序列

    動態(tài)規(guī)劃--最長公共子序列

    動態(tài)規(guī)劃算法與分治法類似,其基本思想也是將待求解問題分解成若干個子問題﹐ 即將大規(guī)模變成小規(guī)模 ,先求解子問題,然后從這些子問題的解得到原問題的解。與分治法不同的是﹐適合于用動態(tài)規(guī)劃法求解的問題,經(jīng)分解得到的子問題往往不是互相獨立的。 他們之間有關(guān)系

    2024年02月04日
    瀏覽(31)
  • 動態(tài)規(guī)劃——最長公共子序列

    動態(tài)規(guī)劃——最長公共子序列

    先來講解以下什么是最長公共子序列。最長公共子序列不是最長相同字符串,有點相似但不一樣,來舉個簡單的例子,有字符串s1=bcdea,s2=abce,最長相同字符串是bc,最大公共部分是2;而最長公共子序列則是bce,最大公共部分是3??梢钥闯?,公共子序列不需要連續(xù)相等,有相

    2023年04月19日
    瀏覽(25)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包