Leetcode-​2537. 统计好子数组的数目​

Problem: 2537. 统计好子数组的数目

思路

滑动窗口

解题过程

思路:

使用滑动窗口来维护子数组,并通过组合计数动态调整满足条件的数对数目。具体来说,我们维护一个窗口[l,r],使得窗口内相同元素的对数至少为 k,并计算这样的窗口数目。

关键观察:

  • 当一个元素的频次从 c 增加到 c+1 时,新增加的数对数目为 c(因为新元素可以与之前的 c 个元素形成 c 对)。
    • 当一个元素的频次从 c 减少到 c-1 时,减少的数对数目为 c-1(因为移除的元素与剩余的 c-1 个元素的数对被移除)。

      算法步骤:

      • 使用两个指针 l 和 r 维护滑动窗口,使用哈希表 cnt 记录元素频次,使用变量 t 记录窗口内的数对数目。
        • 右指针 r 不断扩展窗口,更新元素频次和数对数目 t。
          • 当 t >= k 时,尝试移动左指针 l 缩小窗口,同时更新数对数目 t,直到窗口不再满足条件。
            • 此时,以 r 结尾且满足条件的子数组数目为 l(即左端点可以是 0 到 l-1 的任意位置)。

            Code

            python

            class Solution:def countGood(self, nums: List[int], k: int) -> int:n = len(nums)ans = 0l = 0cnt = defaultdict(int)  # 记录数组中的元素频次t = 0  # 记录此时窗口的满足i<j且nums[i]=nums[j]的对数for r, x in enumerate(nums):cnt[x] += 1if cnt[x] >= 2:t += cnt[x] - 1while t >= k and l < r:cnt[nums[l]] -= 1if cnt[nums[l]] >= 1:t -= cnt[nums[l]]l += 1ans += lreturn ans

            c++

            class Solution {
            public:long long countGood(vector<int>& nums, int k) {int n = nums.size();long long ans = 0;int l = 0;unordered_map<int, int> cnt;int t = 0;for (int r = 0; r < n; r++) {cnt[nums[r]]++;if (cnt[nums[r]] >= 2)t += cnt[nums[r]] - 1;while (t >= k && l < r) {cnt[nums[l]]--;if (cnt[nums[l]] >= 1)t -= cnt[nums[l]];l++;}ans += l;}return ans;}
            };

            复杂度

            • 时间复杂度: O(n)
            • 空间复杂度: O(n),用哈希表存储元素频次。

              本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
              如若转载,请注明出处:http://www.pswp.cn/web/83974.shtml
              繁体地址,请注明出处:http://hk.pswp.cn/web/83974.shtml

              如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

              相关文章

              js手写代码篇--手写Object.assign

              19、Object.assign 作用&#xff1a; Object.assign的作用是将源对象的所有可枚举属性复制到目标对象中。它返回目标对象。 const obj1 { a: 1, b: 2 };const obj2 { b: 3, c: 4 };const obj3 { d: 5 };const target {};Object.assign(target, obj1, obj2, obj3);console…

              使用 C/C++ 和 OpenCV 构建智能停车场视觉管理系统

              使用 C 和 OpenCV 构建智能停车场视觉管理系统 本文将详细介绍如何利用 C 和 OpenCV 库&#xff0c;从零开始创建一个智能停车场管理系统。该系统通过摄像头捕捉的画面&#xff0c;能自动完成两项核心任务&#xff1a; 车位识别&#xff1a;通过检测地面上的黄色停车线&#…

              服务器静态ip,网关不能占用*.*.*.1

              网关不能占用*.*.*.1.1 通常用于运行关键服务&#xff08;如DHCP、NAT、DNS代理&#xff09;&#xff0c;.1 是网络世界的"VIP包厢"&#xff0c;普通用户强闯只会被"请出"。

              自然语言处理【NLP】—— CBOW模型

              文章目录 引言一、CBOW模型概述1.1 什么是CBOW模型1.2 CBOW vs Skip-gram 二、CBOW模型原理详解2.1 模型架构2.2 数学原理2.3 训练过程 三、CBOW的PyTorch实现四、CBOW模型的应用与优化4.1 典型应用场景4.2 性能优化技巧 五、CBOW的局限性六、结语 引言 在自然语言处理(NLP)领…

              为MTK 9300开发板移植Linux系统(以Debian为例)的详细技术指南

              以下是为MTK 9300开发板移植Linux系统(以Debian为例)的详细技术指南,涵盖环境搭建、内核移植、驱动适配(摄像头/显示器/WiFi)、系统集成与优化。 MTK 9300开发板Linux系统移植全流程指南 1 项目概述 1.1 硬件平台 SoC:MediaTek MTK9300 (ARMv8-A架构,4Cortex-A78 + 4C…

              Java Lambda 表达式与 Stream API 全解析:从基础到进阶

              以下是对您博客内容的优化版本&#xff0c;在保留原有核心内容的基础上&#xff0c;补充了Lambda表达式及Stream API的完整方法体系&#xff0c;并通过结构化排版和扩展说明提升可读性。 Java Lambda表达式与Stream API全解析&#xff1a;从基础到进阶 一、Lambda表达式与Str…

              Let’s Encrypt(乐此加密) 免费SSL证书申请

              一、前言 腾讯云、阿里云等平台都支持免费的SSL证书申请&#xff0c;但只支持单域名SSL证书申请&#xff0c;不支持泛域名证书申请&#xff0c;而且每年只有20张免费证书额度&#xff0c;自2024年4月25日之起免费申请的证书只有3个月有效期。域名比较多的情况下&#xff0c;更新…

              SQLite3 性能优化

              在嵌入式开发和轻量级应用场景中&#xff0c;SQLite3 作为轻量级数据库引擎&#xff0c;凭借其无需独立服务器、部署便捷等特点被广泛应用。然而&#xff0c;当面对大量数据的高速读写需求时&#xff0c;默认配置下的 SQLite3 性能往往难以满足要求。本文将从数据库配置调整、W…

              零基础设计模式——行为型模式 - 状态模式

              第四部分&#xff1a;行为型模式 - 状态模式 (State Pattern) 我们继续学习行为型模式&#xff0c;接下来是状态模式。这个模式允许一个对象在其内部状态改变时改变它的行为&#xff0c;对象看起来就像是改变了它的类。 核心思想&#xff1a;允许一个对象在其内部状态改变时改…

              面向对象面试题集合

              前言 记录面向对象面试题相关内容&#xff0c;方便复习及查漏补缺 题1.简述面向对象&#xff1f;主要特征是什么&#xff1f; 面向对象编程&#xff08;Object-Oriented Programming&#xff0c;简称OOP&#xff09;是一种以“对象”为核心的编程范式&#xff0c;通过将现实…

              二十一、【用户管理与权限 - 篇三】角色管理:前端角色列表与 CRUD 实现

              【用户管理与权限 - 篇三】角色管理:前端角色列表与 CRUD 实现 前言准备工作第一部分:更新 API 服务以包含角色管理第二部分:添加角色管理页面的路由和侧边栏入口第三部分:实现角色列表页面第四部分:实现角色表单对话框组件第五部分:全面测试总结前言 一个完善的权限系统…

              Objective-c protocol 练习

              题目描述&#xff1a; 请使用 Objective-C 中的 protocol 协议机制&#xff0c;实现一个简易的门禁控制系统。 系统包含两个类&#xff1a; AccessControlSystem —— 门禁系统&#xff0c;用于执行开门操作&#xff1b;Admin —— 实现权限判断逻辑的管理员。 要求如下&am…

              科技创新赋能产业创新,双轮驱动助力新疆高质量发展!

              在新疆维吾尔自治区成立70周年之际&#xff0c;中国产学研合作促进会于6月14日在乌鲁木齐举办“天山对话&#xff1a;推动新疆科技创新与产业创新”盛会。多位院士、专家、学者及企业代表齐聚一堂&#xff0c;探寻推动新疆科技创新和产业创新的新路径、新动能。活动现场&#x…

              C#最佳实践:推荐使用 nameof 而非硬编码名称

              C#最佳实践:推荐使用 nameof 而非硬编码名称 在 C# 编程领域,代码的可维护性、健壮性和可读性是衡量程序质量的重要指标。在日常开发中,我们常常会遇到需要引用类型、成员或变量名称的场景,比如在抛出异常时指定错误相关的变量名、在日志记录中标记关键元素名称等。传统的…

              vue3 iframe 跨域-通讯

              一、基础嵌套方法 直接在 HTML 中使用 <iframe> 标签指定 src 属性&#xff1a; <iframe src"https://目标网址.com" width"800" height"600"></iframe>‌限制‌&#xff1a;若目标网站设置了 X-Frame-Options 响应头&#x…

              Iceberg与Hive集成深度

              一、Iceberg在Hive中的ACID事务实现与实战 1.1 传统Hive的事务局限性 Hive原生仅支持非事务表&#xff08;Non-ACID&#xff09;&#xff0c;存在以下痛点&#xff1a; 不支持行级更新/删除并发写入时数据一致性无法保证无事务回滚机制历史版本查询需手动实现 1.2 Iceberg为…

              深入剖析 Celery:分布式异步任务处理的利器

              本文在创作过程中借助 AI 工具辅助资料整理与内容优化。图片来源网络。 文章目录 引言一、Celery 概述1.1 Celery 的定义和作用1.2 Celery 的应用场景 二、Celery 架构分析2.1 Celery 的整体架构2.2 消息中间件&#xff08;Broker&#xff09;2.3 任务队列&#xff08;Task Que…

              Flask应用中处理异步事件(后台线程+事件循环)的方法(2)

              在上一节&#xff0c;我们讲述了最简单最基础的后线程的建立&#xff0c;现在我们将进行拓展 Flask应用中处理异步事件&#xff08;后台线程事件循环&#xff09;的方法&#xff08;1&#xff09; 在我们的实际应用当中&#xff0c;我们需要定义三个东西 一个多线程的信号旗&am…

              C++(面向对象编程)

              思维导图 面向对象 1.面向对象思想 概念&#xff1a;面向对象编程&#xff08;OOP&#xff09;是一种以对象为基础的编程范式&#xff0c;强调将数据和操作数据的方法封装在一起。这就是上篇文章讲过的。面向过程是以“怎么解决问题”为核心&#xff0c;而面向对象思想在于“谁…

              驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接,

              驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接,Error: “The server selected protocol version TLS10 is not accepted by client preferences [TLS13&#xff0c;TLS12]”. ClientConnectionId:d5fd8d69-ae88-4055-9f6d-6e8515224ce2】。 基本上就是…