欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

C++怎么解決不同的子序列問題

這篇文章主要講解了“C++怎么解決不同的子序列問題”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“C++怎么解決不同的子序列問題”吧!

專注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)洪山免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了超過千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。

不同的子序列

Example 1:

Input: S =

"rabbbit"

, T =

"rabbit"
Output: 3

Explanation:

As shown below, there are 3 ways you can generate "rabbit" from S.
(The caret symbol ^ means the chosen letters)

rabbbit

^^^^ ^^

rabbbit

^^ ^^^^

rabbbit

^^^ ^^^

Example 2:

Input: S =

"babgbag"

, T =

"bag"
Output: 5

Explanation:

As shown below, there are 5 ways you can generate "bag" from S.
(The caret symbol ^ means the chosen letters)

babgbag

^^ ^

babgbag

^^    ^

babgbag

^    ^^

babgbag

  ^  ^^

babgbag

    ^^^

看到有關(guān)字符串的子序列或者配準類的問題,首先應(yīng)該考慮的就是用動態(tài)規(guī)劃 Dynamic Programming 來求解,這個應(yīng)成為條件反射。而所有 DP 問題的核心就是找出狀態(tài)轉(zhuǎn)移方程,想這道題就是遞推一個二維的 dp 數(shù)組,其中 dp[i][j] 表示s中范圍是 [0, i] 的子串中能組成t中范圍是 [0, j] 的子串的子序列的個數(shù)。下面我們從題目中給的例子來分析,這個二維 dp 數(shù)組應(yīng)為:

  ? r a b b b i t
? 1 1 1 1 1 1 1 1
r 0 1 1 1 1 1 1 1
a 0 0 1 1 1 1 1 1
b 0 0 0 1 2 3 3 3
b 0 0 0 0 1 3 3 3
i 0 0 0 0 0 0 3 3
t 0 0 0 0 0 0 0 3

首先,若原字符串和子序列都為空時,返回1,因為空串也是空串的一個子序列。若原字符串不為空,而子序列為空,也返回1,因為空串也是任意字符串的一個子序列。而當原字符串為空,子序列不為空時,返回0,因為非空字符串不能當空字符串的子序列。理清這些,二維數(shù)組 dp 的邊緣便可以初始化了,下面只要找出狀態(tài)轉(zhuǎn)移方程,就可以更新整個 dp 數(shù)組了。我們通過觀察上面的二維數(shù)組可以發(fā)現(xiàn),當更新到 dp[i][j] 時,dp[i][j] >= dp[i][j - 1] 總是成立,再進一步觀察發(fā)現(xiàn),當 T[i - 1] == S[j - 1] 時,dp[i][j] = dp[i][j - 1] + dp[i - 1][j - 1],若不等, dp[i][j] = dp[i][j - 1],所以,綜合以上,遞推式為:

dp[i][j] = dp[i][j - 1] + (T[i - 1] == S[j - 1] ? dp[i - 1][j - 1] : 0)

根據(jù)以上分析,可以寫出代碼如下:

class Solution {
public:
    int numDistinct(string s, string t) {
        int m = s.size(), n = t.size();
        vector<vector<long>> dp(n + 1, vector<long>(m + 1));
        for (int j = 0; j <= m; ++j) dp[0][j] = 1;
        for (int i = 1; i <= n; ++i) {
            for (int j = 1; j <= m; ++j) {
                dp[i][j] = dp[i][j - 1] + (t[i - 1] == s[j - 1] ? dp[i - 1][j - 1] : 0);
            }
        }
        return dp[n][m];
    }
};

感謝各位的閱讀,以上就是“C++怎么解決不同的子序列問題”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對C++怎么解決不同的子序列問題這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

分享題目:C++怎么解決不同的子序列問題
網(wǎng)站URL:http://chinadenli.net/article28/gjcgjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、做網(wǎng)站、定制開發(fā)、品牌網(wǎng)站制作、服務(wù)器托管App開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)