LeetCode940. 不同的子序列 II

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值