LeetCode 2831.找出最长等值子数组(cpp, python3)

题目链接:2831.找出最长等值子数组

> 将元素值为下标索引,将元素在数组nums中的出现位置记录在二维数组position中,position每个下标对应的数组都是下标索引在nums中的出现位置

> 记position的下标为index,index在nums中的出现次数为position[index].size(),记作cnt1,而在nums数组中index第一次出现到最后一次出现,这个范围内nums的元素个数为:position[index][position[index].size() - 1] - position[index][0] + 1,记作cnt2,那么cnt2 - cnt1就等于需要删除的元素的个数,删除之后最长等值数组的长度就等于滑动窗口的right - left + 1

cpp实现:

cpp 复制代码
class Solution {
public:
    int longestEqualSubarray(vector<int>& nums, int k) {
        int ans = 0; // 初始化长度为0
        vector<vector<int>> position(nums.size() + 1); //定义nums中元素出现的下标数组
        for (int i = 0; i < nums.size(); i++) {
            position[nums[i]].push_back(i); 
        }
        for (auto& e : position) { //分别遍历每一个元素所对应的下标
            int left = 0; //滑动窗口初始化左端点为0
            for (int right = 0; right < e.size(); right++) { //不断移动右端点
                while (e[right] - e[left] + 1 - (right - left + 1) > k) { //当需要移除的元素个数大于k时
                    left += 1; //收缩窗口
                }
                ans = max(ans, right - left + 1); //退出循环之后,说明满足条件,更新ans
            }
        }
        return ans;
    }
};

python3实现:

python 复制代码
class Solution:
    def longestEqualSubarray(self, nums: List[int], k: int) -> int:
        ans = 0
        position = [[] for _ in range(len(nums) + 1)]
        for i, x in enumerate(nums):
            position[x].append(i)
        for e in position:
            left = 0
            for right in range(len(e)):
                while e[right] - e[left] + 1 - (right - left + 1) > k:
                    left += 1
                ans = max(ans, right - left + 1)
        return ans
相关推荐
kyle~4 分钟前
导航---Nav2导航框架概览
c++·机器人·ros2·导航
DolphinDB智臾科技5 分钟前
如何用脚本榨出C++级性能?微秒级低延时系统优化深度解析
大数据·c++·时序数据库·低延时·dolphindb
lLinkl10 分钟前
LeetCode-1.两数之和
算法·leetcode·散列表
CodeCraft Studio11 分钟前
国产化Excel开发组件Spire.XLS教程:使用Python批量删除Excel分页符
开发语言·python·excel·python开发·spire.xls·excel api库·excel开发组件
free-elcmacom11 分钟前
深度学习<2>从“看单帧”到“懂故事”:视频模型的帧链推理,藏着机器读懂时间的秘密
人工智能·python·深度学习·音视频
(❁´◡`❁)Jimmy(❁´◡`❁)11 分钟前
F - Manhattan Christmas Tree 2
数据结构·算法
wxdlfkj12 分钟前
从算法溯源到硬件极限:解决微小球面小角度拟合与中心定位的技术路径
人工智能·算法·机器学习
ZAz_13 分钟前
DAY 44 Grad-CAM与Hook函数
python
高洁0113 分钟前
基于Tensorflow库的RNN模型预测实战
人工智能·python·算法·机器学习·django
一起养小猫16 分钟前
LeetCode100天Day5-最小长度子数组与三数之和
算法·leetcode·职场和发展