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;
    }
}
相关推荐
考虑考虑2 小时前
JDK25模块导入声明
java·后端·java ee
_小马快跑_3 小时前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Wect6 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
Re_zero6 小时前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记6 小时前
Spring Boot条件注解详解
java·spring boot
NAGNIP17 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
程序员清风1 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林5511 天前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
颜酱1 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉