前言
经过前期的基础训练以及部分实战练习,粗略掌握了各种题型的解题思路。现阶段开始专项练习。
描述
给你一个下标从 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;
}
}