欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 产业 > Leetcode - 周赛417

Leetcode - 周赛417

2024/10/25 22:27:30 来源:https://blog.csdn.net/m0_74859835/article/details/142714155  浏览:    关键词:Leetcode - 周赛417

目录

一,3304. 找出第 K 个字符 I

二,3305. 元音辅音字符串计数 I

三,3307. 找出第 K 个字符 II


一,3304. 找出第 K 个字符 I

本题数据范围小,可以直接模拟,代码如下:

class Solution {public char kthCharacter(int k) {StringBuilder res = new StringBuilder();res.append('a');int cnt = 1;while(cnt < k){for(int i=0; i<cnt; i++){res.append((char)((res.charAt(i)-'a'+1)%26 + 'a'));}cnt *= 2;}return res.charAt(k-1);}
}

二,3305. 元音辅音字符串计数 I

本题和T3一样,这里就一起讲了,这题使用滑动窗口来做,但是它需要维护两个条件:1.每个元音字母至少出现一次。2.恰好包含 k 个辅音字符。但是我们使用滑窗时,基本维护的都是至多/至少的条件,而这里的2不符合,所以我们可以转换一下:恰好包含 k 个辅音字符 = 至少包含 k 个辅音字符 - 至少包含 k+1 个辅音字符,这样的话,本题就能使用两次滑窗来实现了。

代码如下:

class Solution {public long countOfSubstrings(String word, int k) {char[] ch = word.toCharArray();return f(ch, k) - f(ch, k+1);}long f(char[] ch, int k){Map<Character, Integer> map = new HashMap<>();long ans = 0;int cnt = 0;for(int l=0,r=0; r<ch.length; r++){if("aeiou".indexOf(ch[r]) != -1){ map.merge(ch[r], 1, Integer::sum);}else{cnt++;}while(map.size() == 5 && cnt >= k){if("aeiou".indexOf(ch[l]) != -1){map.merge(ch[l], -1, Integer::sum);if(map.get(ch[l])==0) map.remove(ch[l]);}else{cnt--;}l++;} ans += l;}return ans;}
}

三,3307. 找出第 K 个字符 II

本题可以使用递归的做法,

代码如下:

class Solution {public char kthCharacter(long k, int[] operations) {return dfs(k, 63 - Long.numberOfLeadingZeros(k-1), operations);}char dfs(long k, int i, int[] op){if(i < 0) return 'a';if(k <= 1L<<i) return dfs(k, i-1, op);//在前半段char ans = dfs(k-(1L<<i), i-1, op);//在后半段return (char)('a' + (ans - 'a' + op[i]) % 26);}
} 

 迭代写法:

class Solution {public char kthCharacter(long k, int[] operations) {int n = 63 - Long.numberOfLeadingZeros(k-1);int ans = 0;for(int i=n; i>=0; i--){if(k > (1L<<i)){k -= 1L << i;ans += operations[i];}}return (char)(ans%26 + 'a');}
} 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com