当前位置: 首页 > article >正文

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

给你字符串 s 和整数 k 。

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

英文中的 元音字母 为(aeiou)。

. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=O83Ahttps://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';
    }
}


http://www.kler.cn/a/399766.html

相关文章:

  • 【在Linux世界中追寻伟大的One Piece】手写序列化与反序列化
  • 利用hive元数据统计数据量
  • 编程之路,从0开始:结构体详解
  • 大数据技术Kafka详解 ① | 消息队列(Messages Queue)
  • 微信小程序底部button,小米手机偶现布局错误的bug
  • etcd部署(基于v3.5.15)
  • C++标准模板库 -- map和set
  • 怎么看待Ai发展前景?
  • 用python中的tkinter包实现进度条
  • 【C++】C++11 新特性揭秘:序章
  • window的Anaconda Powershell Prompt 里使用linux 命令
  • AIGC----生成对抗网络(GAN)如何推动AIGC的发展
  • 11.12.2024刷华为OD-集合的使用,递归回溯的使用
  • 【青牛科技】D2030 14W 高保真音频放大电路介绍和应用
  • 使用Mac下载MySQL修改密码
  • 【C++】了解map和set及平衡二叉树和红黑树的原理
  • 使用docker快速部署Nginx、Redis、MySQL、Tomcat以及制作镜像
  • ArcGIS Pro的arpx项目在ArcGIS Server中发布要素服务(FeatureServer)
  • ue中使用webui有效果白色拖动条 有白边
  • 【C++】构造与析构函数