LeetCode 115. 不同的子序列

題目

給定一個(gè)字符串 s 和一個(gè)字符串 t ,計(jì)算在 s 的子序列中 t 出現(xiàn)的個(gè)數(shù)。字符串的一個(gè) 子序列 是指,通過(guò)刪除一些(也可以不刪除)字符且不干擾剩余字符相對(duì)位置所組成的新字符串。(例如,"ACE" 是 "ABCDE" 的一個(gè)子序列,而 "AEC" 不是)
題目數(shù)據(jù)保證答案符合 32 位帶符號(hào)整數(shù)范圍。

例:
輸入:s = "rabbbit", t = "rabbit"
輸出:3
解釋?zhuān)?br> 如下圖所示, 有 3 種可以從 s 中得到 "rabbit" 的方案。
rabbbit
rabbbit
rabbbit

方法:動(dòng)態(tài)規(guī)劃
  • dp[i][j] 表示以 i-1 為結(jié)尾的字符串 s 中出現(xiàn)以 j-1 為結(jié)尾的字符串 t 的個(gè)數(shù)

  • 初始化

    • dp[0][0] 表示以 -1 為結(jié)尾的字符串 s 中出現(xiàn)以 -1 為結(jié)尾的字符串 t 的個(gè)數(shù),即空字符串中出現(xiàn)空字符串的個(gè)數(shù),所以設(shè)置為 1
    • dp[i][0] 表示以 i-1 為結(jié)尾的字符串 s 中出現(xiàn)以 -1 為結(jié)尾的字符串 t 的個(gè)數(shù),即以 i-1 為結(jié)尾的字符串 s 中出現(xiàn)空字符串的個(gè)數(shù),所以設(shè)置為 1
    • dp[0][j] 表示以 -1 為結(jié)尾的字符串 s 中出現(xiàn)以 j-1 為結(jié)尾的字符串 t 的個(gè)數(shù),即空字符串為中出現(xiàn)以 j-1 為結(jié)尾的字符串 t 的個(gè)數(shù),所以設(shè)置為 0
  • 外部循環(huán)為對(duì)字符串 s 的循環(huán),內(nèi)部循環(huán)為對(duì)字符串 t 的循環(huán)

    • 若兩個(gè)字符串的字符相同,即 s[i-1] == t[j-1],那么此時(shí)的 dp[i][j] 由兩部分組成:將 s[i-1] 與 t[j-1] 進(jìn)行匹配,那么此時(shí)的 dp[i][j] 為以 i-2 為結(jié)尾的字符串 s 中出現(xiàn)以字符串 j-2 為結(jié)尾的字符串 t 的個(gè)數(shù),即 dp[i-1][j-1];將 s[i-1] 不與 t[j-1] 進(jìn)行匹配,那么此時(shí)的 dp[i][j] 為以 i-2 為結(jié)尾的字符串 s 中出現(xiàn)以字符串 j-1 為結(jié)尾的字符串 t 的個(gè)數(shù),即 dp[i-1][j]
    • 若兩個(gè)字符串的字符不同,即 s[i-1] ≠ t[j-1],那么此時(shí)的 dp[i][j] 為以 i-2 為結(jié)尾的字符串 s 中出現(xiàn)以字符串 j-1 為結(jié)尾的字符串 t 的個(gè)數(shù),即 dp[i-1][j]
class Solution(object):
    def numDistinct(self, s, t):
        dp = [[0] * (len(t)+1) for row in range(len(s)+1)]
        for i in range(len(s)+1):
            dp[i][0] = 1
        for i in range(1, len(s)+1):
            for j in range(1, len(t)+1):
                if s[i-1] == t[j-1]:
                    dp[i][j] = dp[i-1][j-1] + dp[i-1][j]
                else:
                    dp[i][j] = dp[i-1][j]
        return dp[-1][-1]
參考

代碼相關(guān):https://programmercarl.com/0115.%E4%B8%8D%E5%90%8C%E7%9A%84%E5%AD%90%E5%BA%8F%E5%88%97.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 不同的子序列 思路 動(dòng)態(tài)規(guī)劃 dp[i][j]表示S前i個(gè)字符 中 T前j個(gè)字符的個(gè)數(shù)。 則有如下遞推公式 如果 ...
    lucasgao閱讀 209評(píng)論 0 0
  • 題目描述 給定一個(gè)字符串 S 和一個(gè)字符串 T,計(jì)算在 S 的子序列中 T 出現(xiàn)的個(gè)數(shù)。 一個(gè)字符串的一個(gè)子序列是...
    算法碼上來(lái)閱讀 204評(píng)論 0 0
  • 題意 給定一個(gè)字符串 s 和一個(gè)字符串 t ,計(jì)算在 s 的子序列中 t 出現(xiàn)的個(gè)數(shù)。 字符串的一個(gè) 子序列 是指...
    ST_碼閱讀 301評(píng)論 0 0
  • 不同的子序列 給定一個(gè)字符串 s 和一個(gè)字符串 t ,計(jì)算在 s 的子序列中 t 出現(xiàn)的個(gè)數(shù)。 字符串的一個(gè) 子序...
    一個(gè)酷酷的男子閱讀 250評(píng)論 0 0
  • 問(wèn)題115:給定一個(gè)字符串S和一個(gè)字符串T,計(jì)算在S的子序列中T出現(xiàn)的次數(shù)。 一個(gè)字符串的一個(gè)子序列是指,通過(guò)刪除...
    嚕嚕666閱讀 291評(píng)論 0 0

友情鏈接更多精彩內(nèi)容