力扣(LeetCode)115. 不同的子序列(C++)
创始人
2024-02-29 23:20:04
0

动态规划

pp
状态转移方程
f[i,j]={f[i−1,j]f[i−1,j]+f[i−1,j−1]if s[i]=t[j]f[i,j]=\begin{cases} f[i-1,j]\\ f[i-1,j]+f[i-1,j-1]&\text{if } s[i]=t[j] \end{cases}f[i,j]={f[i−1,j]f[i−1,j]+f[i−1,j−1]​if s[i]=t[j]​

无论选不选 s[i]s[i]s[i] , f[i][j]f[i][j]f[i][j] 一定包含 f[i−1][j]f[i-1][j]f[i−1][j] ,即 s[1s[1s[1~i−1]i-1]i−1] 含有 t[1t[1t[1~j]j]j] 的方案全部顺延过来。

如果选 s[i]s[i]s[i] ,仅当 s[i]=t[j]s[i]=t[j]s[i]=t[j] , f[i][j]f[i][j]f[i][j] 包含 f[i−1][j−1]f[i-1][j-1]f[i−1][j−1] 。即 s[1s[1s[1~i−1]i-1]i−1] 生成 t[1t[1t[1~j−1]j-1]j−1] 的方案全部顺延过来。

class Solution {
public:int numDistinct(string s, string t) {int n = s.size(), m = t.size();s = ' ' + s, t= ' ' + t;vector> f(n+1,vector(m+1,0));for(int i = 0;i<=n;i++) f[i][0] = 1;for(int i = 1; i<=n;i++)for(int j = 1;j<=m;j++){f[i][j] = f[i-1][j];if(s[i]==t[j]) f[i][j]+=f[i-1][j-1];f[i][j]%=INT_MAX;}return f[n][m];}
};
  1. 时间复杂度 : O(n×m)O(n\times m)O(n×m) , nnn 是字符串 sss 的长度 , mmm 是字符串 ttt 的长度,状态转移的时间复杂度 O(n×m)O(n\times m)O(n×m) 。
  2. 空间复杂度 : O(n×m)O(n\times m)O(n×m) , 所有状态的空间复杂度 O(n×m)O(n\times m)O(n×m) 。

AC

AC

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
苏州离哪个飞机场近(苏州离哪个... 本篇文章极速百科小编给大家谈谈苏州离哪个飞机场近,以及苏州离哪个飞机场近点对应的知识点,希望对各位有...
客厅放八骏马摆件可以吗(家里摆... 今天给各位分享客厅放八骏马摆件可以吗的知识,其中也会对家里摆八骏马摆件好吗进行解释,如果能碰巧解决你...