5919. 所有子字符串中的元音

题目链接:力扣

思路:很明显这是一个求贡献的题~~求每个元音字符的贡献,然后求和。首先大家肯定会想到暴力,一看数据量不行,那就想到求贡献~~

举个例子:abcdefg

e这个元音字符能做的贡献有哪儿些字符呢?

我是想到用两部分合起来的:

第一部分:abcde、bcde、cde、de、e、ef、efg 这一部分的贡献值是字符串的长度也就是7,怎么算呢?就是 len-i+i = len i表示当前字符的位置(从0开始)。这一部分的特点是e都在子字符串的边上,也就是没有跨过e的两边。

第二部分:abcdef、abcdefg、bcdef、bcdefg、cdef、cdefg、def、defg。这一部分的贡献值是e的两边的字符串的数目求乘积。怎么算呢?(len-i-1)*i i表示当前字符的位置(从0开始)。这一部分的特点是e都在子字符串的中间,跨过了e的两边。

注意:第二部分计算的时候会爆int(坑点)

上代码:

class Solution {
    fun countVowels(word: String): Long {
        var cnt = 0L
        val len = word.length
        for (i in word.indices) {
            if (word[i] == 'a' || word[i] == 'e' || word[i] == 'i' || word[i] == 'o' || word[i] == 'u') {
                cnt += (len - i - 1) * 1L * i + len - i + i
            }
        }
        return cnt
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

心脏dance

如果解决了您的疑惑,谢谢打赏呦

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值