LeetCode第 310 场周赛

简介: LeetCode第 310 场周赛

第86场双周赛情况


地址:第310场周赛



战绩:



第三题案例超时了:



最后的情况:



目前竞赛分数:



题目复盘+题解


题1:6176. 出现最频繁的偶数元素【easy】


题目链接:6176. 出现最频繁的偶数元素


题目内容:


给你一个整数数组 nums ,返回出现最频繁的偶数元素。
如果存在多个满足条件的元素,只需要返回 最小 的一个。如果不存在这样的元素,返回 -1 。
示例 1:
输入:nums = [0,1,2,2,4,4,1]
输出:2
解释:
数组中的偶数元素为 0、2 和 4 ,在这些元素中,2 和 4 出现次数最多。
返回最小的那个,即返回 2 。
示例 2:
输入:nums = [4,4,4,9,2,4]
输出:4
解释:4 是出现最频繁的偶数元素。
示例 3:
输入:nums = [29,47,21,41,13,37,25,7]
输出:-1
解释:不存在偶数元素。
提示:
1 <= nums.length <= 2000
0 <= nums[i] <= 105



思路:


1、哈希表+一遍遍历


复杂度分析:时间复杂度O(n);空间复杂度O(n)


class Solution {
    public int mostFrequentEven(int[] nums) {
        int max = -1;
        int res = -1;
        Map<Integer, Integer> map = new HashMap<>();
        for (int num: nums) { 
            //偶数
            if ((num & 1) == 0) {
                int val = map.getOrDefault(num, 0) + 1;
                map.put(num, val);
                if (val == max && num < res) {
                    res = num;
                }
                if (val > max) {
                    max = val;
                    res = num;
                }
            }
        }
        return res;
    }
}




题2:6176. 出现最频繁的偶数元素【medium】


题目链接:6177. 子字符串的最优划分


题目内容:


给你一个字符串 s ,请你将该字符串划分成一个或多个 子字符串 ,并满足每个子字符串中的字符都是 唯一 的。也就是说,在单个子字符串中,字母的出现次数都不超过 一次 。
满足题目要求的情况下,返回 最少 需要划分多少个子字符串。
注意,划分后,原字符串中的每个字符都应该恰好属于一个子字符串。
示例 1:
输入:s = "abacaba"
输出:4
解释:
两种可行的划分方法分别是 ("a","ba","cab","a") 和 ("ab","a","ca","ba") 。
可以证明最少需要划分 4 个子字符串。
示例 2:
输入:s = "ssssss"
输出:6
解释:
只存在一种可行的划分方法 ("s","s","s","s","s","s") 。
提示:
1 <= s.length <= 105
s 仅由小写英文字母组成



思路:


1、滑动窗口+哈希表


复杂度分析:时间复杂度O(n);空间复杂度O(1)


class Solution {
    public int partitionString(String s) {
        char[] arr = s.toCharArray();
        int[] tb = new int[26];
        int res = 0;
        for (int l = 0, r = 0; r < arr.length; r++) {
            if (tb[arr[r] - 'a'] == 1) {
                res++;
                //清理工作
                while (l < r) {
                    tb[arr[l] - 'a'] = 0;
                    l++;
                }
                //此时l == r
            }
            tb[arr[r] - 'a']++;
        }
        return res + 1;
    } 
}



题3:6178. 将区间分为最少组数【medium】


题目链接:6178. 将区间分为最少组数


题目内容:


给你一个二维整数数组 intervals ,其中 intervals[i] = [lefti, righti] 表示 闭 区间 [lefti, righti] 。
你需要将 intervals 划分为一个或者多个区间 组 ,每个区间 只 属于一个组,且同一个组中任意两个区间 不相交 。
请你返回 最少 需要划分成多少个组。
如果两个区间覆盖的范围有重叠(即至少有一个公共数字),那么我们称这两个区间是 相交 的。比方说区间 [1, 5] 和 [5, 8] 相交。
示例 1:
输入:intervals = [[5,10],[6,8],[1,5],[2,3],[1,10]]
输出:3
解释:我们可以将区间划分为如下的区间组:
- 第 1 组:[1, 5] ,[6, 8] 。
- 第 2 组:[2, 3] ,[5, 10] 。
- 第 3 组:[1, 10] 。
可以证明无法将区间划分为少于 3 个组。
示例 2:
输入:intervals = [[1,3],[5,6],[8,10],[11,13]]
输出:1
解释:所有区间互不相交,所以我们可以把它们全部放在一个组内。
提示:
1 <= intervals.length <= 105
intervals[i].length == 2
1 <= lefti <= righti <= 106



思路:


1、暴力法【超时,当时就卡住了】


复杂度分析:时间复杂度O(n2);空间复杂度O(n)


public int minGroups(int[][] intervals) {
    Arrays.sort(intervals, (o1, o2)->o1[0] - o2[0]);
    boolean[] visited = new boolean[intervals.length];
    int res = 0;
    for (int i = 0; i < intervals.length; i++) {
        if (visited[i]) continue;
        int[] interval = intervals[i];
        for (int j = i + 1; j < intervals.length; j++) {
            if (intervals[j][0] > interval[1] && !visited[j]) {
                visited[j] = true;
                interval = intervals[j];
            }
        }
        res++;
    }
    return res;
}



2、小根堆+排序


复杂度分析:时间复杂度O(nlogn);空间复杂度O(n);


class Solution {
    //排序+小根堆
    public int minGroups(int[][] intervals) {
        //排序
        Arrays.sort(intervals, (o1, o2)->o1[0] - o2[0]);
        //小根堆(储存right的值)
        PriorityQueue<Integer> queue = new PriorityQueue<>();
        for (int[] arr: intervals) {
            if (!queue.isEmpty()) {
                //若是时间比最小的久那么就移除最小的,加入最新的实现一个替换
                if (arr[0] > queue.peek()) {
                    queue.poll();
                }
            }
            queue.offer(arr[1]);
        }
        return queue.size();
    }
}




复盘:当时根据开始时间排序是想到的,但是对应小根堆的一个贪心应用这个方式还是第一次碰到。


题4:6206. 最长递增子序列 II【hard,暂未ac】


题目链接:6206. 最长递增子序列 II


题目内容:


给你一个整数数组 nums 和一个整数 k 。
找到 nums 中满足以下要求的最长子序列:
子序列 严格递增
子序列中相邻元素的差值 不超过 k 。
请你返回满足上述要求的 最长子序列 的长度。
子序列 是从一个数组中删除部分元素后,剩余元素不改变顺序得到的数组。
示例 1:
输入:nums = [4,2,1,4,3,4,5,8,15], k = 3
输出:5
解释:
满足要求的最长子序列是 [1,3,4,5,8] 。
子序列长度为 5 ,所以我们返回 5 。
注意子序列 [1,3,4,5,8,15] 不满足要求,因为 15 - 8 = 7 大于 3 。
示例 2:
输入:nums = [7,4,5,1,8,12,4,7], k = 5
输出:4
解释:
满足要求的最长子序列是 [4,5,8,12] 。
子序列长度为 4 ,所以我们返回 4 。
示例 3:
输入:nums = [1,5], k = 1
输出:1
解释:
满足要求的最长子序列是 [1] 。
子序列长度为 1 ,所以我们返回 1 。
提示:
1 <= nums.length <= 105
1 <= nums[i], k <= 105


思路:①线段树。②树状数组。


题解暂时无,主要是目前还没有能力做出来这题,先这边标记下吧,花了一下午时间学了学线段树,不过对于该题题解还是没能够解出来。

相关文章
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
280页PDF,全方位评估OpenAI o1,Leetcode刷题准确率竟这么高
【10月更文挑战第24天】近年来,OpenAI的o1模型在大型语言模型(LLMs)中脱颖而出,展现出卓越的推理能力和知识整合能力。基于Transformer架构,o1模型采用了链式思维和强化学习等先进技术,显著提升了其在编程竞赛、医学影像报告生成、数学问题解决、自然语言推理和芯片设计等领域的表现。本文将全面评估o1模型的性能及其对AI研究和应用的潜在影响。
99 1
|
5月前
|
数据采集 负载均衡 安全
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
|
5月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
6月前
|
Python
【Leetcode刷题Python】1467. 两个盒子中球的颜色数相同的概率
本文介绍了LeetCode第50题"Pow(x, n)"的解法,题目要求实现计算x的n次幂的函数,文章提供了递归分治法的详细解析和Python实现代码。
75 0
|
6月前
|
Python
【Leetcode刷题Python】50. Pow(x, n)
本文介绍了LeetCode第50题"Pow(x, n)"的解法,题目要求实现计算x的n次幂的函数,文章提供了递归分治法的详细解析和Python实现代码。
38 1
|
6月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
146 2
|
6月前
|
算法 Python
【Leetcode刷题Python】73. 矩阵置零
本文介绍了LeetCode第73题的解法,题目要求在给定矩阵中将所有值为0的元素所在的行和列全部置为0,并提供了一种原地算法的Python实现。
54 0
【Leetcode刷题Python】73. 矩阵置零
|
6月前
|
Python
【Leetcode刷题Python】LeetCode 478. 在圆内随机生成点
本文介绍了LeetCode 478题的解法,题目要求在给定圆的半径和圆心位置的情况下实现在圆内均匀随机生成点的功能,并提供了Python的实现代码。
47 1
|
6月前
|
算法 Python
【Leetcode刷题Python】 LeetCode 2038. 如果相邻两个颜色均相同则删除当前颜色
本文介绍了LeetCode 2038题的解法,题目要求在一个由'A'和'B'组成的字符串中,按照特定规则轮流删除颜色片段,判断Alice是否能够获胜,并提供了Python的实现代码。
69 3
|
6月前
|
算法 Python
【Leetcode刷题Python】295. 数据流的中位数
本文介绍了一种使用Python实现的数据结构,用以支持数据流中添加整数并返回当前所有元素的中位数,通过排序列表来计算中位数。
47 1