[滑动窗口] 13. 水果成篮

一. 题目描述



题目简述: 找出一个最长的连续区域(最长子数组),使这个连续的区域中最多有两种水果类型。

二. 解题思路

1)首先想到暴力解法,两个指针枚举所有子数组,并通过map或unordered_map充当篮子来建立水果类型和数量间的映射,表中元素不能超过2。

**2)优化:**当出现第三种类型时,当前left的所有情况就结束了,固定下一个left时,right只可能不动或前进,一定不需要返回,所以两指针同向前进,是滑动窗口。

3)具体步骤:

  1. 进窗口:将当前fruitsright放到哈希表中,并将映射值,即该种类水果的数量++。

  2. 判断是否需要出窗口:如果哈希表中元素个数(即水果种类数)超过2(只有两个篮子也就只能装两种类型的水果),则需要出窗口:将fruitsleft类型对应的数量--,并判断此次--之后篮子中是否还有该种类的水果,如果没有了(mfruits\[left] == 0),就把该种类从哈希表中移除。

  3. 更新结果:此时篮中水果一定是符合要求的,更新结果。

根据提示信息,水果的类型数不会超过10^5,那么我们就可以用一个数组来模拟哈希表,将对哈希表的增删差改,变成对数组做操作,提升效率。

三. 代码实现

1)使用容器

unordered_map和map都可以,推荐unordered_map效率更高

cpp 复制代码
class Solution 
{
public:
    int totalFruit(vector<int>& fruits) 
    {
        int left = 0, right = 0, maxnum = 0;
        unordered_map<int, int> m;

        for(; right < fruits.size(); right++)
        {
            m[fruits[right]]++;

            while(m.size() > 2)
            {
                m[fruits[left]]--;
                if(m[fruits[left]] == 0) m.erase(fruits[left]);
                left++;
            }

            maxnum = max(maxnum, right - left + 1);
        }
        return maxnum;
    }
};

2)数组模拟哈希表

数据范围有限的情况下,可以用数组模拟哈希表,提高效率。

cpp 复制代码
class Solution 
{
public:
    int totalFruit(vector<int>& fruits) 
    {
        int left = 0, right = 0, maxnum = 0;
        int m[100001] = {0};

        for(int kind = 0; right < fruits.size(); right++)
        {
            if(m[fruits[right]] == 0) kind++;
            m[fruits[right]]++;

            while(kind > 2)
            {
                m[fruits[left]]--;
                if(m[fruits[left]] == 0) kind--;
                left++;
            }

            maxnum = max(maxnum, right - left + 1);
        }
        return maxnum;
    }
};
相关推荐
huohaiyu28 分钟前
深入解析Java垃圾回收机制
java·开发语言·算法·gc
浮芷.35 分钟前
鸿蒙PC端 TTS 并发调用问题详解:资源竞争与队列管理
算法·华为·开源·harmonyos·鸿蒙·鸿蒙系统
装不满的克莱因瓶43 分钟前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
Lsk_Smion44 分钟前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论
轻微的风格艾丝凡1 小时前
两电平三相VSC整流模式从不控整流平滑切换至有源整流调试记录
算法·dsp·c2000
dongf20191 小时前
R语言KNN算法
算法·数据分析·r语言
小O的算法实验室1 小时前
2025年IEEE TASE,基于双层耦合平均场博弈的大规模智能体集成任务分配与轨迹规划
人工智能·算法·机器学习
8Qi82 小时前
LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅
算法·leetcode·二叉树·动态规划
地平线开发者2 小时前
从 INT64 Div 算子约束到 Cast 修复全流程
算法
2601_961194022 小时前
教资科三美术考什么|初中高中美术题型考点和模板资料
leetcode·elasticsearch·职场和发展·蓝桥杯·pat考试·lucene