滑动窗口入门(LeetCode——1456定长字符串中元音字母的最大数目)

给你字符串 s 和整数 k

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

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

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/maximum-number-of-vowels-in-a-substring-of-given-length

1、暴力

直接暴力枚举所有子串并且比对每一个字串中的字符是否为元音字母,很明显这样的时间复杂度高,太慢了

2、滑动窗口

我们在字符串s中选取k个字符逐一比对并且记录下当前最大元音字母数,在暴力中我们需要前移动一个字符并且从头比对起,但是很明显我们可以只去比对移动后新增的字符是否为元音字母,若为元音字母,则最大元音字母数+1,注意在移动的过程中我们移开的那个字符也应该再比对一次若为元音字母,则最大元音字母数-1。

复制代码
class Solution {
    public int maxVowels(String s, int k) {
        //将字符串复制到字符数组中
        char[] input = s.toCharArray();
        //当前窗口中元音字母数
        int sum = 0;
        //最大元音字母数
        int answer = 0;
        //循环数组中每一个字符
        for (int i = 0; i < input.length; i++) {
            //判断是否为元音字母
            if (is(input[i])) {
                sum++;
            }
            //判断窗口大小,若没检查完整个窗口则跳过后面继续检查
            if (i < k - 1) {
                continue;
            }
            //检查完窗口所有字符后更新答案
            answer = answer > sum ? answer : sum;
            //判断移开的字符是否为元音
            if (is(input[i - k + 1])) {
                sum--;
            }
        }
        return answer;

    }
    //判断元音
    public boolean is(char c) {
        return c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u';
    }
}
相关推荐
To_OC1 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
小bo波5 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking5 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
用户938515635076 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC7 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥8 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
张不才8 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
地平线开发者9 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者9 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
shepherd1119 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构