IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> leetcode 992. K 个不同整数的子数组—(每日一难day12) -> 正文阅读

[数据结构与算法]leetcode 992. K 个不同整数的子数组—(每日一难day12)

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

给定一个正整数数组 nums和一个整数 k ,返回 num 中 「好子数组」 的数目。

如果 nums 的某个子数组中不同整数的个数恰好为 k,则称 nums 的这个连续、不一定不同的子数组为 「好子数组 」。

例如,[1,2,3,1,2] 中有 3 个不同的整数:1,2,以及 3。
子数组 是数组的 连续 部分。

示例 1:

输入:nums = [1,2,1,2,3], k = 2
输出:7
解释:恰好由 2 个不同整数组成的子数组:[1,2], [2,1],[1,2], [2,3], [1,2,1], [2,1,2], [1,2,1,2].

示例 2:

输入:nums = [1,2,1,3,4], k = 3
输出:3
解释:恰好由 3 个不同整数组成的子数组:[1,2,1,3],[2,1,3], [1,3,4].

提示:

1 <= nums.length <= 2 * 1e4
1 <= nums[i], k <= nums.length

解析

  1. 如果寻找最多包含k个不同数字的连续子数组应该怎么做?

    • 采用双指针的方法。
    • 分别以数组内的每个数作为右指针,也就是子区间的结尾(连续区间的套路),计算出符合区间内数字种类小于等于k个的所有区间数。每个结尾对应的区间总数累加起来就是区间总数。
    • 如果在右指针移动的过程中,区间数超过了k个,那么就要移动左指针,直至小于等于k个。
    • 记录区间数种类可以使用数组,因为给定的数据范围不大。
  2. 恰好包含k个,可以转化为最多包含k个-最多包含k-1个,这样就得到恰好包含的k个的区间数。

  3. 滑动窗口的特点,
    (1)区间需要满足固定的状态(种类数固定)
    (2)区间状态随着右指针移动逐渐不符合,左指针移动可以重新回到这种状态(右动多,左动少,满足状态就计数)
    (3)有一种随着像右移动单调的感觉(本题就是数字种类只会越来越多)
    例如:1 2 1 3 4 ,k=2.
    首先,最多包含两个,分别以1 2 1 3 4,作为区间的结尾。
    1)1结尾,满足最多包含两个的区间数为1(1)
    2)2结尾,满足最多包含两个的区间数为2(2 12)
    3)1结尾,满足最多包含两个的区间数为3(1 12 121)
    4)3结尾,满足最多包含两个的区间数为3(3 31 312)
    5)4结尾,满足最多包含两个的区间数为3(4 43 431)
    因此,最多包含2个不同数的区间为g(2)=1+2+3+3+3=12个
    同理,最多包含一个数的区间为,g(1)=1+1+1+1+1=5个
    因此,恰好为2个的区间数位 12 - 5 = 7

code

class Solution {
public:
   int ok(vector<int>& nums,int k){
       int n=nums.size();
       // 区间内数字种类
       int cnt=0;
       // 记录区间内有哪些数字,以及数量
       vector<int> vis(n+1,0);
       int l=0,r=0;
       int res=0;
       while(r<n){
           if(!vis[nums[r]])
               cnt++; 
           vis[nums[r]]++;
           // 不符合,左指针移动,直到符合状态
           while(cnt>k){
               vis[nums[l]]--;
               if(!vis[nums[l++]])
                   cnt--;
           }
           // 以r结尾的子区间数
           res+=r-l+1;
           r++;
       }
       return res;
   }
   int subarraysWithKDistinct(vector<int>& nums, int k) {
       return ok(nums,k)-ok(nums,k-1);
   }
};

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-05-07 11:22:23  更:2022-05-07 11:25:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 16:27:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码