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

一. 题目描述



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

二. 解题思路

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

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

3)具体步骤:

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

  2. 判断是否需要出窗口:如果哈希表中元素个数(即水果种类数)超过2(只有两个篮子也就只能装两种类型的水果),则需要出窗口:将fruits[left]类型对应的数量--,并判断此次--之后篮子中是否还有该种类的水果,如果没有了(m[fruits[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;
    }
};
相关推荐
khalil10201 小时前
代码随想录算法训练营Day-52 图论03 | 101.孤岛的总面积、102.沉没孤岛、103.水流问题、104.建造最大岛屿
c++·算法·图论
刀法如飞1 小时前
Palantir技术原理深度分析:Ontology 存储结构与读写方式
人工智能·算法·架构
澈2071 小时前
图论基础:邻接矩阵与邻接表详解
算法·图论·邻接矩阵
白日做梦Q1 小时前
Miniconda 新手保姆级教程:从安装到熟练使用(全程无跳步,避坑指南附全)
人工智能·深度学习·算法·机器学习
吃好睡好便好2 小时前
在Matlab中绘制变半径柱面图
开发语言·人工智能·学习·算法·matlab
拂拉氏2 小时前
【知识讲解-题目讲解】:二叉树的前、中、后序遍历的三种实现(递归,非递归,Morris遍历)与二叉树oj题讲解(二叉树最近公共祖先,二叉树展开为链表)
数据结构·算法·leetcode·二叉树·遍历
luck_bor2 小时前
File 类核心笔记
java·前端·算法
anew___2 小时前
从高方差到稳定训练:深度强化学习算法演进全解析
算法
大大杰哥2 小时前
2026陕西省ICPC省赛补题(前六题)
c++·算法