最多K个重复元素的最长子数组

1. 题目

给你一个整数数组 nums 和一个整数 k 。

一个元素 x 在数组中的 频率 指的是它在数组中的出现次数。

如果一个数组中所有元素的频率都 小于等于 k ,那么我们称这个数组是  数组。

请你返回 nums 中 最长好 子数组的长度。

子数组 指的是一个数组中一段连续非空的元素序列。

2. 示例

示例 1:

输入:nums = [1,2,3,1,2,3,1,2], k = 2
输出:6
解释:最长好子数组是 [1,2,3,1,2,3] ,值 1 ,2 和 3 在子数组中的频率都没有超过 k = 2 。[2,3,1,2,3,1] 和 [3,1,2,3,1,2] 也是好子数组。
最长好子数组的长度为 6 。

示例 2:

输入:nums = [1,2,1,2,1,2,1,2], k = 1
输出:2
解释:最长好子数组是 [1,2] ,值 1 和 2 在子数组中的频率都没有超过 k = 1 。[2,1] 也是好子数组。
最长好子数组的长度为 2 。

示例 3:

输入:nums = [5,5,5,5,5,5,5], k = 4
输出:4
解释:最长好子数组是 [5,5,5,5] ,值 5 在子数组中的频率没有超过 k = 4 。
最长好子数组的长度为 4 。

3. 思路

        这道题目是一道滑动窗口类型的题目,当时比赛的时候一直没想起怎么移动,想着靠哈希表来存储每个数的第一个索引来移动窗口左边界,在比完后看到一个大佬的题解犹如醍醐灌顶,咱们可以在遍历的for循环里面套个循环来模拟移动窗口左边界,然后在每次遍历结束后更新最大值。下面是示例1的动画演示:

最多k个重复元素的最长子数组

4. 代码

class Solution:
    def maxSubarrayLength(self, nums: List[int], k: int) -> int:
        left = 0    # 初始窗口左边界
        Max = 0    # 最大值
        cnt = Counter()    # 哈希表结构,比字典好用
        for right,x in enumerate(nums):    # 遍历数组,right为有边界索引,x为当前值
            cnt[x] += 1 # 将当前数的次数+1
            while cnt[x] > k:    # 尝试移动窗口左边界
                cnt[nums[left]] -= 1   # 在右移的过程将该数出现的次数-1
                left += 1     # 不断向右移动窗口的左边界
            Max = max(Max,right - left + 1)    # 更新最大值
        return Max    # 返回结果

5. 结果显示

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小人物₍˄·͈༝·͈˄*₎◞ ̑̑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值