• 904. 水果成篮(滑动窗口)


    目录

    一、题目

    二、代码


    一、题目

     力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

    二、代码

    • 题目实质:找出一个最长的子数组的长度,要求子数组中不超过两种类型的水果
    • 哈希表+双指针 
    1. class Solution {
    2. public:
    3. int totalFruit(vector<int>& fruits) {
    4. int _MaxCount = INT_MIN;
    5. int _Sum = 0;//总的水果种类
    6. vector<int>FruitType(100001, 0);//存放水果的种类
    7. vector<int>FruitCount(100001, 0);//不同种类水果的数量
    8. for (int left = 0, right = 0; right < fruits.size(); right++)
    9. {
    10. ++FruitCount[fruits[right]];//进窗口,对应种类的水果数量+1
    11. if (FruitType[fruits[right]] == 0)//如果某种水果的数量是0
    12. {
    13. FruitType[fruits[right]] = 1;
    14. _Sum++;//总的水果种类+1
    15. }
    16. if (_Sum <= 2)
    17. {
    18. _MaxCount = max(_MaxCount, right - left + 1);//更新
    19. continue;
    20. }
    21. if (_Sum > 2)//判断,水果种类大于2
    22. {
    23. _MaxCount = max(_MaxCount, right - left);//更新(次数fruits[right]处是第3种类型,所以左闭右开)
    24. int mark = fruits[left];
    25. while (fruits[left] == mark)//left右移,将连续相同的种类出窗口
    26. {
    27. ++left;
    28. --FruitCount[fruits[left - 1]];
    29. }
    30. if (FruitCount[fruits[left - 1]] == 0)//当移动到某种类水果数量为0的时候
    31. {
    32. FruitType[fruits[left - 1]] = 0;//将不存在对应的种类
    33. --_Sum;//总的水果种类-1
    34. }
    35. }
    36. }
    37. return _MaxCount;
    38. }
    39. };

    改进:

    1. class Solution {
    2. public:
    3. int totalFruit(vector<int>& f)
    4. {
    5. int _MaxCount = INT_MIN;
    6. unordered_map<int, int> hash;//下标表示水果的种类,存放某种类水果数量
    7. for (int left = 0, right = 0; right < f.size(); right++)
    8. {
    9. ++hash[f[right]];//进窗口
    10. while (hash.size() > 2)
    11. {
    12. //出窗口
    13. --hash[f[left]];//某种类水果数量-1
    14. if (hash[f[left]] == 0)//如果某种类水果数量为0,则删除该种类
    15. {
    16. hash.erase(f[left]);
    17. }
    18. left++;
    19. }
    20. _MaxCount = max(_MaxCount, right - left + 1);
    21. }
    22. return _MaxCount;
    23. }
    24. };

  • 相关阅读:
    k8s--docker状态码(很重要)
    java生成自定义长度的唯一随机字符串
    Java技术之高频面试题
    StarRocks入门之路
    身体是革命的本钱,希望大家编程之余努力搞好身体
    Intel汇编-数组遍历
    NODEJS杂记
    栈溢出至getshell分析及利用
    springboot配置文件自定义为json格式
    【前端面试常问】计算属性 computed 与监听属性 watch
  • 原文地址:https://blog.csdn.net/m0_63783532/article/details/133964495