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 分钟前
美团研发岗 5月9号笔试真题 - 正整数矩阵
算法·美团笔试真题·美团研发岗笔试真题·美团0509笔试真题
Rabitebla1 分钟前
C++ 多态详解:从概念到虚表底层原理(代码轰炸)
开发语言·c++
Smilecoc4 分钟前
决策树(二):决策树的划分选择
算法·决策树·机器学习
布朗克1687 分钟前
33 设计模式精讲
java·单例模式·设计模式
砍材农夫12 分钟前
python 如何一次性安装项目所有依赖包(pip和uv)
开发语言·python·pip·uv
IpdataCloud13 分钟前
信贷审核中如何验证用户地址与IP属地一致性?用IP查询工具实现反欺诈
开发语言·tcp/ip·金融·php·ip
hetao173383714 分钟前
2026-05-25~06-11 hetao1733837 的刷题记录
c++·算法
cheems952718 分钟前
[算法手记] 滑动窗口最大值
算法
洛水水19 分钟前
【力扣100题】82.有效的括号
c++·算法·leetcode
XGeFei21 分钟前
时序算法 —— LSTM、ARIMA、随机森林
算法·随机森林·lstm