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;
    }
}
相关推荐
EvenBoy4 小时前
IDEA中使用CodeX
java·ide·intellij-idea
水蓝烟雨4 小时前
3335. 字符串转换后的长度 I
算法·leetcode
日取其半万世不竭4 小时前
Minecraft Java版社区服搭建教程(Windows版)
java·开发语言·windows
Dxy12393102164 小时前
HTML 如何使用 SVG 画曲线
前端·算法·html
wjs20244 小时前
HTML 文本格式化
开发语言
逸Y 仙X5 小时前
文章十六:ElasticSearch 使用enrich策略实现大宽表
java·大数据·数据库·elasticsearch·搜索引擎·全文检索
westdata-Tm5 小时前
洛谷P1219 [USACO1.5] 八皇后 Checker Challenge
算法·深度优先·dfs
白夜11175 小时前
C++任务调度与状态机
开发语言·c++·笔记
风筝在晴天搁浅5 小时前
手撕快速排序
数据结构
南宫萧幕5 小时前
MATLAB/Simulink 从零打通:HEV 能量管理 GA 联合仿真保姆级建模指南
开发语言·算法·matlab·汽车·控制·pid