leetcode前缀和(2559. 统计范围内的元音字符串数)

前言

经过前期的基础训练以及部分实战练习,粗略掌握了各种题型的解题思路。现阶段开始专项练习。

描述

给你一个下标从 0 开始的字符串数组 words 以及一个二维整数数组 queries 。

每个查询 queries[i] = [li, ri] 会要求我们统计在 words 中下标在 li 到 ri 范围内(包含 这两个值)并且以元音开头和结尾的字符串的数目。

返回一个整数数组,其中数组的第 i 个元素对应第 i 个查询的答案。

注意:元音字母是 'a''e''i''o' 和 'u' 。

示例 1:

输入:words = ["aba","bcb","ece","aa","e"], queries = [[0,2],[1,4],[1,1]]
输出:[2,3,0]
解释:以元音开头和结尾的字符串是 "aba"、"ece"、"aa" 和 "e" 。
查询 [0,2] 结果为 2(字符串 "aba" 和 "ece")。
查询 [1,4] 结果为 3(字符串 "ece"、"aa"、"e")。
查询 [1,1] 结果为 0 。
返回结果 [2,3,0] 。

示例 2:

输入:words = ["a","e","i"], queries = [[0,2],[0,1],[2,2]]
输出:[3,2,1]
解释:每个字符串都满足这一条件,所以返回 [3,2,1] 。

提示:

  • 1 <= words.length <= 105
  • 1 <= words[i].length <= 40
  • words[i] 仅由小写英文字母组成
  • sum(words[i].length) <= 3 * 105
  • 1 <= queries.length <= 105
  • 0 <= queries[j][0] <= queries[j][1] < words.length

实现原理与步骤

 实现代码

class Solution {

    public int[] vowelStrings(String[] words, int[][] queries) {
        int len=words.length;
        int[] sums=new int[len+1];
        for(int i=0;i<len;i++){
            String word=words[i];
            if(isYuanyin(word.charAt(0))&&isYuanyin(word.charAt(word.length()-1))){
                sums[i+1]=sums[i]+1;
            }else{
                sums[i+1]=sums[i];
            }
        }
        int[] res=new int[queries.length];
        for(int i=0;i<queries.length;i++){
            int left=queries[i][0];
            int right=queries[i][1];
            res[i]=sums[right+1]-sums[left];
        }
        return res;
    }


    public boolean isYuanyin(char a){
        if(a=='a'||a=='e'||a=='i'||a=='o'||a=='u'){
            return true;
        }
        return false;
    }
}

1.QA:

最长元音字符串问题的解法可以通过遍历字符串中的每个字符,判断其是否为元音字母,并记录连续出现的元音字母的个来实现。这个问题可以使用双指针的方法来解决。 我们可以使用两个指针start和end,初始时均指向字符串的第一个字符。然后,我们开始遍历字符串中的每个字符。如果当前字符是元音字母,我们就将end指针向后移动一位,并记录下两个指针之间的元音字母的个。如果当前字符不是元音字母,我们就将start指针指向end指针的下一个位置,并将end指针指向下一个字符。 在遍历过程中,每次更新最长元音字符串的长度,如果遇到更长的元音字符串,就用当前长度更新最长元音字符串的长度。 遍历结束后,最长元音字符串的长度就是我们要求的结果。 以下是使用Java语言实现的代码: ```java public class LongestVowelString { public static int maxLengthOfVowelString(String s) { int start = 0; int end = 0; int maxLen = 0; int currLen = 0; while (end < s.length()) { char c = s.charAt(end); if (isVowel(c)) { currLen++; end++; maxLen = Math.max(maxLen, currLen); } else { start = end + 1; end++; currLen = 0; } } return maxLen; } private static boolean isVowel(char c) { return c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u'; } public static void main(String[] args) { String s = "leetcode"; int maxLength = maxLengthOfVowelString(s); System.out.println("最长元音字符串的长度为:" + maxLength); } } ``` 以上代码中,我们先定义了一个`maxLengthOfVowelString`方法,它接受一个字符串作为输入,并返回最长元音字符串的长度。我们还定义了一个`isVowel`方法,用于判断一个字符是否为元音字母。在`main`方法中,我们将一个示例字符串传入`maxLengthOfVowelString`方法,并打印出最长元音字符串的长度。运行该程序,输出结果为: ``` 最长元音字符串的长度为:3 ``` 因此,在给定的示例字符串"leetcode"中,最长的元音字符串为"eeo",其长度为3。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值