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');
    }
} 
相关推荐
Hello娃的5 分钟前
【半导体】肖特基接触AND欧姆接触
人工智能·算法
橘颂TA5 分钟前
【剑斩OFFER】算法的暴力美学——交易逆序对的总数
数据结构·算法·leetcode
xiyuping249 分钟前
强化学习之——moutaincar
算法·机器学习
小画家~11 分钟前
第三十七:类型断言
开发语言·c++·算法·golang
九年义务漏网鲨鱼14 分钟前
【大模型微调】QLoRA微调原理及实战
深度学习·算法·大模型·智能体
2401_8414956414 分钟前
【LeetCode刷题】合并区间
数据结构·python·算法·leetcode·合并·遍历·排序
测试人社区-千羽15 分钟前
构建卓越体验:UX测试评估标准的系统框架与实践指南
人工智能·语言模型·自然语言处理·职场和发展·aigc·ux
努力学算法的蒟蒻22 分钟前
day20(12.10)——leetcode面试经典150
面试·职场和发展
xu_yule24 分钟前
数据结构(14)二叉树的模拟实现和便利代码
数据结构·算法
代码游侠35 分钟前
应用——文件I/O操作代码
linux·运维·c语言·笔记·学习·算法