Post

leetcode 1456 定长子串中元音的最大数目

leetcode 1456 定长子串中元音的最大数目

定长子串中元音的最大数目

题目

给你字符串 s 和整数 k 。

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

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

解题思路

这是一个典型的定长滑动窗口,解题思路为入-更新-出

入:下标为 i 的元素进入窗口,更新相关统计量。如果窗口左端点 i−k+1<0,则尚未形成第一个窗口,重复第一步。 更新:更新答案。一般是更新最大值/最小值。 出:下标为 i−k+1 的元素离开窗口,更新相关统计量,为下一个循环做准备。

注意边界: 出的时候窗口大小大小为k,出之后大小为k-1,此时R-L+1=k, L=R-k+1

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
func isVowel(c byte) bool {
    return c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u'
}

func maxVowels(s string, k int) int {
    ans := 0
    cnt := 0

    for i := range len(s) {
        if isVowel(s[i]) {
            cnt++
            ans = max(ans, cnt)
        }
        if i < k - 1 {
            continue
        }
        // 将更新挪到入时的那一步可以剪枝
        if isVowel(s[i - k + 1]) {
            cnt--
        }
    }
    return ans
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
fn is_vowels(c: u8) -> bool {
    if c == b'a' || c == b'e' || c == b'i' || c == b'o' || c == b'u' {
        return true
    }
    false
}

impl Solution {
    pub fn max_vowels(s: String, k: i32) -> i32 {
        let s = s.as_bytes();
        let k = k as usize;
        let mut ans = 0;
        let mut vowel = 0;
        for (i, &c) in s.iter().enumerate() {
            if is_vowels(c) {
                vowel += 1;
                ans = ans.max(vowel);
            }
            if i < k - 1 {
                continue;
            }
            if is_vowels(s[i - k + 1]) {
                vowel -= 1;
            }
        }
        ans
    }
}
This post is licensed under CC BY 4.0 by the author.