文章目录

  • 前言
  • 第86场双周赛情况
  • 题目复盘+题解
    • 题1:6176. 出现最频繁的偶数元素【easy】
    • 题2:6176. 出现最频繁的偶数元素【medium】
    • 题3:6178. 将区间分为最少组数【medium】
    • 题4:6206. 最长递增子序列 II【hard,暂未ac】

前言

之后会参与leetcode周赛、双周赛,希望自己能够坚持下来,并以此来督促检验、提升自己的算法能力,加油!

第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

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

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

学习索引:值域线段树(Python/Java/C++/Go)

LeetCode第 310 场周赛相关推荐

  1. Leetcode第 310 场周赛 补打

    Leetcode 第310场周赛 自己赛后打了一下,记录了一下时间,大概15min A 3题,第四题是写不出来,然后学习了一天线段树(真的强). 思路: 1.排序后统计偶数的数目 2.遍历扫一遍,用直 ...

  2. [LeetCode周赛复盘] 第 310 场周赛20220911

    [LeetCode周赛复盘] 第 310 场周赛20220911 一.本周周赛总结 二. [Easy] 6176. 出现最频繁的偶数元素 1. 题目描述 2. 思路分析 3. 代码实现 三.[Medi ...

  3. LeetCode第 227 场周赛题解

    LeetCode第 227 场周赛题解 检查数组是否经排序和轮转得到 原题链接 https://leetcode-cn.com/problems/check-if-array-is-sorted-an ...

  4. LeetCode 第 194 场周赛

    LeetCode 第 194 场周赛 数组异或操作 思路和代码 保证文件名唯一 思路及代码 避免洪水泛滥 思路及代码 找到最小生成树里的关键边和伪关键边 思路及代码 这次周赛比以往难很多. 数组异或操 ...

  5. LeetCode第187场周赛(Weekly Contest 187)解题报告

    差点又要掉分了,还好最后几分钟的时候,绝杀 AK.干巴爹!!! 第一题:思路 + 模拟暴力. 第二题:线性扫描. 第三题:双指针(滑动窗口) + 优先队列. 第四题:暴力每一行最小 k 个 + 优先队 ...

  6. Acwing第72场周赛+Leetcode第314场周赛

    Acwing第72场周赛 第一题:AcWing 4624. 最小值 分析:向下取整可以用到math.h头文件中的floor()函数,最后输出时套用两个min()函数求三个数的最小值即可. 代码: #i ...

  7. LeetCode第176场周赛(Weekly Contest 176)解题报告

    又是一周掉分之旅,我发现,LeetCode周赛的数据好水,所以有的时候,实在没思路,先暴力解决试试(即使分析出时间复杂度会超时),比如第二题和第三题都可以暴力通过,GG思密达. 这周主要使用了数据结构 ...

  8. Leetcode第321场周赛补题

    Leetcode第321场周赛补题 第一题:6245. 找出中枢整数 - 力扣(LeetCode) 分析:由于数组中是差值为1的等差数列,所以可以直接用等差数列求和公式的朴素法更加简便的解决这题,,其 ...

  9. [算法]LeetCode第194场周赛202006021

    第194场周赛 20200621 1486. 数组异或操作 题目描述1 给你两个整数,n 和 start . 数组 nums 定义为:nums[i] = start + 2*i(下标从 0 开始)且 ...

最新文章

  1. 【Avalon】Avalon笔记(解析Dom模板树,按自己的规范)
  2. centos7 安装rabbitMQ3.6.6
  3. 华为服务器怎么查看系统日志,华为日志服务器
  4. Elastic Jeff Yoshimura:开源正在开启新一轮的创新 | 人物志
  5. 前辈学习C语言的四种方法,实际上不管学什么语言,都行之有效!
  6. 全Flash网站和单个Flash作品制作的区别
  7. cvi调用matlab dll,cvi通过artix调用matlab
  8. cad细等线体不显示_CAD技法大全,如何在CAD中解决好部分图元无法正常显示的问题 ?...
  9. 如果软件也玩凡尔赛文学,将如何对话?
  10. 7.1.Zeng_Cache(2) --- 缓存原理
  11. 不用找,你想要的简约ppt模板素材都在这里
  12. javaweb网上人才招聘系统的设计与实现
  13. 机器学习(2)——监督学习
  14. marlin固件函数解析
  15. 银行核心业务系统性能测试方法
  16. android数据格式化,手机格式化了?教你找回安卓手机误删数据
  17. 海天蚝油《挑战不可能》7岁神童”盲棋“对抗,展现惊人脑力
  18. Nagios-config
  19. 程序员面试时应该知道的福利待遇
  20. 【快递下单小程序源码】可运营+快递下单微信小程序

热门文章

  1. 我如何在咨询项目中使用Vagrant和Docker
  2. 打倒虚伪的动物福利者!
  3. 为什么高防CDN将成为网站安全防护的必备?
  4. HDU 4833 Best Financing DP
  5. Android在线源码网站推荐
  6. 统计结合python_python 练习(一)代码统计工具的实现
  7. 拿下人脸识别“世界杯”冠军!松下-NUS 和美国东北大学实战分享
  8. opencv——图片找不同
  9. java对接支付宝支付(手机网站支付)
  10. Windows系统简体中文版官方镜像大全