leetCode第310场周赛

这篇博客探讨了三个算法问题:1) 寻找数组中最频繁出现的偶数;2) 字符串的最优划分,确保每个子字符串中字符唯一;3) 将不相交区间划分为最少的组。这些问题都涉及到了哈希表的使用,通过统计和比较找出最优解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

T1:出现最频繁的偶数元素
给你一个整数数组 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
解释:不存在偶数元素。
这个题目的思路非常简单,就是用map记录每个元素出现的次数,并找出出现次数最多的值。然后再在map中找最大值对应的第一次出现的元素。(因为要求次数相同时返回的是较小的,所以这个题用map,如果题目对返回的值不做要求,只要求最频繁出现,则可以用unordered_map)。

class Solution {
public:
    int mostFrequentEven(vector<int>& nums) {
        int n = nums.size();
        map<int,int>hash;
        int sum = 0;
        int res = -1;
        for(auto c : nums){
            if(c % 2 ==0){
                hash[c]++;
                sum = max(sum ,hash[c]);
            }
        }
        for(auto&[c,count]:hash){
            if(count == sum){
                res = c;
                break;
            }
        }
        return res;
    }
};

T2:子字符串的最优划分
给你一个字符串 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时,就清空该哈希表,然后进行下一次计数。

class Solution {
public:
    int partitionString(string s) {
        int res = 0;
        map<char,int>hash;
        for(int i = 0 ; i < s.size() ; i++){
            if(!hash.count(s[i])){
            hash[s[i]]++;
            }
            else{
                hash.clear();
                res++;
                hash[s[i]]++;
            }
        }
        
        return res+1;
    }
};

T3:将区间分为最少组数
给你一个二维整数数组 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,结束位置-1,这样就可以得到一个类似下图粉色数字的数组(未标记位置为0),对这个数组求前缀和就可以知道每个位置区间的个数。这样我们找到某一位置区间重合的最大个数就好了。

在这里插入图片描述

class Solution {
public:
    const int N = 1e6+10;
    int minGroups(vector<vector<int>>& intervals) {
        int res = 0 ;
        vector<int>a(N);
        for(auto c : intervals){
            a[c[0]]++;
            a[c[1]+1]--;
        }
        vector<int>pre(N);
        pre[0] = a[0];
        for(int i = 1; i < a.size();i++){
            pre[i] = pre[i-1] + a[i];
            res = max(res,pre[i]);
        }
        return res;
    }
};
### LeetCode周赛概述 LeetCode周赛是一项在线编程竞赛活动,旨在帮助程序员提升算法能力并准备技术面试。参与者可以在规定的时间内解决一系列具有挑战性的编程问题[^1]。 ### 参加方法 为了参与LeetCode周赛,用户需先注册一个LeetCode账号,并定期关注官方公告获取最新的赛事通知。比赛通常会在周末举行,在比赛当天登录网站进入指定的比赛页面即可开始作答。对于初次参赛者来说,可能会遇到一些操作上的不熟悉,比如不清楚在哪里提交解答等问题,但随着经验积累这些问题都会迎刃而解[^2]。 ### 比赛时间安排 LeetCode周赛一般固定在北京时间每周日凌晨01:00(UTC/GMT+8)准时开赛,持续时间为两小时。在此期间,选手可以自由选择任意连续的两个小时完成比赛中的题目。需要注意的是,具体的比赛日期和时间可能因节假日等因素有所调整,请务必留意官网发布的最新消息[^4]。 ### 题目类型分析 比赛中涉及的题目种类繁多,涵盖了数据结构、算法设计等多个方面。常见的题目形式包括但不限于: - 数组与字符串处理 - 动态规划 - 图论及其应用 - 排序与查找技巧 - 栈队列等高级数据结构的应用 这些题目往往要求较高的逻辑思维能力和扎实的基础知识掌握程度。例如,在某些情况下,一道看似简单的数组运算题也可能隐藏着深层次的数据结构优化思路;而在另一些景下,则需要运用到复杂的动态规划策略来解决问题[^5]。 ```python def example_function(input_data): """ 这是一个示例函数,用于展示如何编写Python代码。 参数: input_data (list): 输入的数据列表 返回: result (int): 计算后的结果值 """ # 处理输入数据... processed_data = sorted(input_data) # 执行核心计算逻辑... result = sum(processed_data[:3]) return result ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值