【从零开始的LeetCode-算法】1456. 定长子串中元音的最大数目

给你字符串 s 和整数 k

请返回字符串 s 中长度为 k 的单个子字符串中可能包含的最大元音字母数。

英文中的 元音字母 为(a, e, i, o, u)。

示例 1:

复制代码
输入:s = "abciiidef", k = 3
输出:3
解释:子字符串 "iii" 包含 3 个元音字母。

示例 2:

复制代码
输入:s = "aeiou", k = 2
输出:2
解释:任意长度为 2 的子字符串都包含 2 个元音字母。

示例 3:

复制代码
输入:s = "leetcode", k = 3
输出:2
解释:"lee"、"eet" 和 "ode" 都包含 2 个元音字母。

示例 4:

复制代码
输入:s = "rhythms", k = 4
输出:0
解释:字符串 s 中不含任何元音字母。

示例 5:

复制代码
输入:s = "tryhard", k = 4
输出:1

提示:

  • 1 <= s.length <= 10^5
  • s 由小写英文字母组成
  • 1 <= k <= s.length

我的解答:

java 复制代码
class Solution {
    public int maxVowels(String s, int k) {
        int res = 0;
        int[] nums = new int[s.length()];
        Arrays.fill(nums,0);
        for(int i = 0;i < s.length();i++){
            // 非元音字母以0表示,元音字母以1表示
            if(s.charAt(i) == 'a' || s.charAt(i) == 'e' || s.charAt(i) == 'i' || s.charAt(i) == 'o' || s.charAt(i) == 'u'  )
            {
                nums[i] = 1;
            }
        }
        int d = 0;
        for(int i = 0; i < nums.length;i++){
            // 记入每段长度为k的字符串中的元音字母数
            d += i < k ? nums[i] : nums[i] - nums[i-k];
            res = Math.max(d,res);
        }
        return res;
    }
}
相关推荐
式5164 分钟前
线性代数(七)主变量与特解
线性代数·算法
业精于勤的牙6 小时前
浅谈:算法中的斐波那契数(二)
算法·职场和发展
陈文锦丫6 小时前
MQ的学习
java·开发语言
乌暮6 小时前
JavaEE初阶---线程安全问题
java·java-ee
爱笑的眼睛116 小时前
GraphQL:从数据查询到应用架构的范式演进
java·人工智能·python·ai
不穿格子的程序员6 小时前
从零开始写算法——链表篇4:删除链表的倒数第 N 个结点 + 两两交换链表中的节点
数据结构·算法·链表
liuyao_xianhui7 小时前
寻找峰值--优选算法(二分查找法)
算法
dragoooon347 小时前
[hot100 NO.19~24]
数据结构·算法
Seven977 小时前
剑指offer-52、正则表达式匹配
java
代码or搬砖7 小时前
RBAC(权限认证)小例子
java·数据库·spring boot