Leetcode - 周赛417

目录

[一,3304. 找出第 K 个字符 I](#一,3304. 找出第 K 个字符 I)

[二,3305. 元音辅音字符串计数 I](#二,3305. 元音辅音字符串计数 I)

[三,3307. 找出第 K 个字符 II](#三,3307. 找出第 K 个字符 II)


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

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

java 复制代码
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 个辅音字符,这样的话,本题就能使用两次滑窗来实现了。

代码如下:

java 复制代码
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

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

代码如下:

java 复制代码
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);
    }
} 

迭代写法:

java 复制代码
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');
    }
} 
相关推荐
꧁༺❀氯ྀൢ躅ྀൢ❀༻꧂6 分钟前
实验4 循环结构
c语言·算法·基础题
新晓·故知31 分钟前
<基于递归实现线索二叉树的构造及遍历算法探讨>
数据结构·经验分享·笔记·算法·链表
总裁余(余登武)42 分钟前
算法竞赛(Python)-万变中的不变“随机算法”
开发语言·python·算法
Eric.Lee20211 小时前
音频文件重采样 - python 实现
人工智能·python·深度学习·算法·audio·音频重采样
一个不知名程序员www1 小时前
leetcode第189题:轮转数组(C语言版)
c语言·leetcode
huapiaoy1 小时前
Redis中数据类型的使用(hash和list)
redis·算法·哈希算法
冷白白1 小时前
【C++】C++对象初探及友元
c语言·开发语言·c++·算法
鹤上听雷2 小时前
【AGC005D】~K Perm Counting(计数抽象成图)
算法
武昌库里写JAVA2 小时前
【Java】Java面试题笔试
c语言·开发语言·数据结构·算法·二维数组