C.滑动窗口-求子数组个数-越短越合法——LCP 68. 美观的花束

题目链接:LCP 68. 美观的花束(中等)

算法原理:

解法:滑动窗口

击败18.18%

时间复杂度O(N)

1️⃣进窗口:将该种类的花在哈希表中的次数+1

2️⃣出窗口:数量超过cnt的只能是当前新进入窗口的花,如果>cnt就持续收缩左端点

3️⃣更新:因为是求子数组个数,所以ret+=right-left+1

Java代码:

java 复制代码
class Solution {
    public int beautifulBouquet(int[] nums, int k) {
        int n=nums.length,ret=0;
        //存<花类别,数量>
        Map<Integer,Integer> hash=new HashMap<>();
        for(int left=0,right=0;right<n;right++){
            //进窗口
            int in=nums[right];
            hash.put(in,hash.getOrDefault(in,0)+1);
            //出窗口:只有当前新加入窗口的值可能数量超过k,所以没必要再遍历一遍哈希表
            while(hash.get(in)>k){
                    int out=nums[left];
                    hash.put(out,hash.get(out)-1);
                    if(hash.get(out)==0) hash.remove(out);
                    left++;
                }
            //更新
            ret+=right-left+1;
        }
        return ret;
    }
}
相关推荐
测试员周周1 小时前
【Appium 系列】第16节-WebView-H5上下文切换 — 混合应用的自动化难点
运维·开发语言·人工智能·功能测试·appium·自动化·测试用例
Mahir083 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
杜子不疼.3 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
加号33 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
sycmancia4 小时前
Qt——编辑交互功能的实现
开发语言·qt
RyFit4 小时前
SpringAI 常见问题及解决方案大全
java·ai
石山代码5 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家5 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事5 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海5 小时前
C# 隐式转换深度解析
java·开发语言·c#