难度:困难
给定一个字符串 s,计算 s 的 不同非空子序列 的个数。因为结果可能很大,所以返回答案需要对 10^9 + 7 取余 。
字符串的 子序列 是经由原字符串删除一些(也可能不删除)字符但不改变剩余字符相对位置的一个新字符串。
- 例如,
"ace"是"abcde"的一个子序列,但"aec"不是。
输入:s = "abc"
输出:7
解释:7 个不同的子序列分别是 "a", "b", "c", "ab", "ac", "bc", 以及 "abc"。
输入:s = "aba"
输出:6
解释:6 个不同的子序列分别是 "a", "b", "ab", "ba", "aa" 以及 "aba"。
输入:s = "aaa"
输出:3
解释:3 个不同的子序列分别是 "a", "aa" 以及 "aaa"。
/**
* 动态规划
* @desc 时间复杂度 O(N+|Σ|) 空间复杂度 O(|Σ|)
* @param s
* @returns
*/
export function distinctSubseqII(s: string): number {
const MOD = 1000000007
const g = new Array(26).fill(0)
const n = s.length; let total = 0
for (let i = 0; i < n; ++i) {
const oi = s[i].charCodeAt(0) - 'a'.charCodeAt(0)
const prev = g[oi]
g[oi] = (total + 1) % MOD
total = ((total + g[oi] - prev) % MOD + MOD) % MOD
}
return total
}