news 2026/6/9 22:06:42

双指针专题(十):恰好等于的困境——「K 个不同整数的子数组」

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
双指针专题(十):恰好等于的困境——「K 个不同整数的子数组」

场景想象:你是一个统计员,要把数组切成很多段。 老板要求:每一段里必须恰好包含K种不同的数字。

  • 比如[1, 2, 1, 2, 3],K=2

  • [1, 2, 1, 2]是符合的(只有 1 和 2 两种)。

  • [1, 2, 1, 2, 3]不符合(有 3 种)。

  • [1]不符合(只有 1 种)。

难点:滑动窗口最擅长处理的是“最多 K 个”(类似《水果成篮》)或者“至少 K 个”。 对于“恰好 K 个”,窗口的左边界很难确定。因为“恰好 2 个”的情况可能有很多种(比如[1, 2][1, 2, 1]都是),左指针到底缩到哪里才算完呢?

力扣 992. K 个不同整数的子数组

https://leetcode.cn/problems/subarrays-with-k-different-integers/

题目分析:

  • 输入:数组nums,整数k

  • 输出:满足条件的子数组数量。

核心思维:恰好(K) = 最多(K) - 最多(K-1)

这是一个非常经典的集合论思想:

  • 最多 K 种:包含“恰好 1 种”、“恰好 2 种” ... “恰好 K 种”。

  • 最多 K-1 种:包含“恰好 1 种” ... “恰好 K-1 种”。

如果你把这两个集合相减,剩下的不就是“恰好 K 种”了吗?

转化优势:“最多包含 K 种整数的子数组数量”非常简单,就是标准的滑动窗口(和《水果成篮》一模一样)。 我们只需要写一个 helper 函数atMost(k),然后调用两次即可:return atMost(k) - atMost(k - 1);

atMost(k)的计数逻辑:当窗口[left, right]满足“最多 K 种”时,以nums[right]结尾的、满足条件的子数组有多少个? 答案是right - left + 1个。

  • 比如[1, 2](K=2)。以 2 结尾的子数组有[2][1, 2],共 2 个。

  • 这个公式累加起来,就是总数。

代码实现 (JavaScript)

JavaScript

/** * @param {number[]} nums * @param {number} k * @return {number} */ var subarraysWithKDistinct = function(nums, k) { // 核心公式:恰好 K = 最多 K - 最多 K-1 return atMost(nums, k) - atMost(nums, k - 1); }; /** * 辅助函数:求最多包含 k 种不同整数的子数组数量 * 这就是标准的滑动窗口模板(类似水果成篮) */ function atMost(nums, k) { let left = 0; let right = 0; let count = 0; // 记录符合条件的子数组总数 let distinctCount = 0; // 当前窗口有多少种不同的数 // 使用数组代替 Map 统计频率,性能会好很多(题目提示 nums[i] <= 20000) // 如果没有范围限制,可以用 Map const freq = new Array(nums.length + 1).fill(0); while (right < nums.length) { // --- 进窗口 --- if (freq[nums[right]] === 0) { distinctCount++; } freq[nums[right]]++; right++; // --- 出窗口 --- // 如果种类超过 k,必须收缩 while (distinctCount > k) { freq[nums[left]]--; if (freq[nums[left]] === 0) { distinctCount--; } left++; } // --- 核心累加 --- // 此时窗口 [left, right-1] 内的种类 <= k // 那么以 right-1 结尾的子数组数量就是窗口长度 count += right - left; } return count; }

深度模拟

假设nums = [1, 2, 1, 2, 3],k = 2

  1. 计算atMost(2):

    • [1]-> +1

    • [1, 2]-> +2 (子数组:2,1,2)

    • [1, 2, 1]-> +3 (子数组:1,2,1,1,2,1)

    • [1, 2, 1, 2]-> +4

    • 遇到 3 (种类变3) -> 缩左边直到[2, 3]-> +2

    • 总数 A

  2. 计算atMost(1):

    • [1]-> +1

    • 遇到 2 (种类变2) -> 缩左边直到[2]-> +1

    • 遇到 1 (种类变2) -> 缩左边直到[1]-> +1

    • ...

    • 总数 B

  3. 结果A - B就是我们要的答案。

总结

恭喜你!🎉 到这里,我们的双指针与滑动窗口专题就彻底结业了!

我们从最简单的快慢指针(移除元素)开始,一路打怪升级,经过了对撞指针(三数之和)、不定长窗口(最小覆盖子串),最后攻克了单调队列(滑动窗口最大值)和数学转换(K个不同整数)。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/23 13:14:59

HunyuanOCR模型对HTML结构化数据的解析能力评估

HunyuanOCR模型对HTML结构化数据的解析能力评估 在企业自动化流程日益复杂的今天&#xff0c;如何高效、准确地从网页中提取关键信息&#xff0c;已成为RPA&#xff08;机器人流程自动化&#xff09;、智能客服、财务系统对接等场景的核心挑战。传统方案依赖XPath、CSS选择器或…

作者头像 李华
网站建设 2026/6/5 23:53:55

清华大学开源镜像站助力HunyuanOCR国内高速下载

清华大学开源镜像站助力HunyuanOCR国内高速下载 在AI技术加速落地的今天&#xff0c;一个看似不起眼却至关重要的问题正悄然影响着国内开发者的效率&#xff1a;如何快速、稳定地获取那些动辄数十GB的开源模型&#xff1f;尤其是在光学字符识别&#xff08;OCR&#xff09;领域…

作者头像 李华
网站建设 2026/6/7 3:59:29

迈克链接器件公司获得 CSconnected 资助

英国公司获供应链发展资助&#xff0c;推进 SALMAT 项目迈克链接器件公司英国分公司&#xff08;MicroLink Devices UK&#xff09;是一家利用外延剥离&#xff08;ELO&#xff09;技术为卫星和飞机制造太阳能阵列的公司。该公司近日获得了一笔资金&#xff0c;用于其 SALMAT&a…

作者头像 李华
网站建设 2026/5/26 3:09:17

揭秘C++加载Stable Diffusion模型全过程:性能提升300%的秘密

第一章&#xff1a;C加载Stable Diffusion模型的技术背景在人工智能生成内容&#xff08;AIGC&#xff09;迅速发展的背景下&#xff0c;Stable Diffusion 作为文本到图像生成领域的代表性模型&#xff0c;已广泛应用于创意设计、艺术生成和工业仿真等场景。尽管其原始实现主要…

作者头像 李华
网站建设 2026/6/4 20:31:36

SEO优化技巧:如何让HunyuanOCR相关内容更容易被搜索到

让HunyuanOCR被更多人看见&#xff1a;技术落地与SEO协同之道 在智能文档处理日益普及的今天&#xff0c;企业对OCR的需求早已不止于“把图片转成文字”。从一张模糊的发票到跨国合同中的多语言段落&#xff0c;再到视频帧里的实时字幕提取&#xff0c;用户期待的是端到端、零配…

作者头像 李华
网站建设 2026/5/21 3:52:33

并发请求支持能力如何?HunyuanOCR服务压力测试结果

并发请求支持能力如何&#xff1f;HunyuanOCR服务压力测试结果 在企业级AI应用日益普及的今天&#xff0c;一个模型能否“扛住流量”&#xff0c;往往比它在榜单上的排名更关键。尤其是在文档自动化、跨境内容处理等高频调用场景中&#xff0c;OCR系统不仅要看得准&#xff0c;…

作者头像 李华