Leetcode每日刷题之904.水果成篮

1.题目解析

本题的题目要求较长,不过理解起来较为简单,就是在给定数组内找出最长子数组,并且该最长子数组只能有两种数字,最后返回该符合条件的最长子数组的长度即可

题目来源: 904.水果成篮

2.算法原理

本题的核心是找出符合条件的最长子数组,首先想到的一定是暴力枚举所有符合条件的子数组最后找出最长的即可

在经过优化的算法就是"滑动窗口"算法,

1.即使用两个指针,让right指针不断向后遍历而left指针不动,在left-right这一段窗口内加入数据称为入窗口

2.当窗口内数字的种类超过两种则开始出窗口,也就是left指针移动而right指针不动,直到窗口中数字种类为2种,这时更新子数组长度

3.这里使用数组hash模仿哈希表,因为由题目可知数组中数字范围小于10^5,所以创建一个hash[100001]即可,然后使用kinds变量统计窗口内数字种类

4.hash[100001]存储每个数字出现的次数,当出窗口时某个数字出现次数为0则将种类kinds--即可,最后更新长度直到找出最长符合子数组的长度即可

3.代码展示

cpp 复制代码
class Solution {
public:
    int totalFruit(vector<int>& fruits) 
    {
        int n = fruits.size();
        int hash[100001] = { 0 };
        int len = 0;
        for(int left = 0,right = 0,kinds = 0;right < n;right++)
        {
            if(hash[fruits[right]] == 0)
            {
                kinds++;
            }
            hash[fruits[right]]++;
            while(kinds > 2)
            {
                hash[fruits[left]]--;
                if(hash[fruits[left]] == 0)
                {
                    kinds--;
                }
                left++;
            }
            len = max(len,right - left + 1);
        }
        return len;
    }
};
相关推荐
颜酱4 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
saltymilk9 小时前
使用 C++ 模拟 ShaderLanguage 的 swizzle
c++·模板元编程
zone77399 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub12 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub12 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub12 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙13 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
xlp666hub16 小时前
Leetcode第五题:用C++解决盛最多水的容器问题
linux·c++·leetcode
CoovallyAIHub16 小时前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
SparkX开源AI知识库17 小时前
手摸手带你安装OpenClaw并对接飞书
算法·架构