所有子字符串中的元音

题目描述

给你一个字符串 word ,返回 word 的所有子字符串中 元音的总数 ,元音是指 'a'、'e'、'i'、'o' 和 'u' 。

子字符串 是字符串中一个连续(非空)的字符序列。

注意:由于对 word 长度的限制比较宽松,答案可能超过有符号 32 位整数的范围。计算时需当心。

 思路分析

  • 带有前缀和的思想,记录以每个当前字符为结尾的所有子字符串的元音个数(累加的),即prevValidCharNum + i + 1
  • 又有dp的思想

Source code

class Solution {
public:
    map<char,int> mp;
    long long countVowels(string word)
    {
        mp['a']=1;mp['e']=1;mp['i']=1;mp['o']=1;mp['u']=1;
        int wrdSize = word.size();
        long long ans = 0;
        long long prevValidCharNum = 0; //除了后面可能加入的元音外,每一个以当前字母结尾的所有字串的元音总数
        if(mp[word[0]]) { ans = 1; prevValidCharNum = 1;} //初始状态

        for(int i = 1; i < wrdSize ; i++){
            if(mp[word[i]]){
                ans += prevValidCharNum + i + 1;
                prevValidCharNum = prevValidCharNum + i + 1;
            }
            else ans += prevValidCharNum;
        }
        return ans;
    }
};

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值