LeetCode940. 不同的子序列 II
题目描述
给定一个字符串 s,计算 s 的 不同非空子序列 的个数。因为结果可能很大,所以返回答案需要对 10^9 + 7 取余 。
字符串的 子序列 是经由原字符串删除一些(也可能不删除)字符但不改变剩余字符相对位置的一个新字符串。
例如,“ace” 是 “abcde” 的一个子序列,但 “aec” 不是
示例
输入:s = “abc”
输出:7
解释:7 个不同的子序列分别是 “a”, “b”, “c”, “ab”, “ac”, “bc”, 以及 “abc”。
要点
- 1 <= s.length <= 2000
- s 仅由小写英文字母组成
解题思路
用一个数组存储26个字母结尾的字符串数量,每往后读一个就把整个数组全加起来再加一更新对应字母结尾的数组,使用该思路还去除了重复字符串的影响,最终构建的line数组存的是以每个字母结尾的拆分字符串数量
Python
class Solution:
def distinctSubseqII(self, s: str) -> int:
aa = list('abcdefghijklmnopqrstuvwxyz')#创建一个26字母索引顺序
line=[0]*26
for i in range(len(s)):
num=0
for j in range(26):
num=(num+line[j])%1000000007
line[aa.index(s[i])]=num+1
result=sum(line)%1000000007
return result