力扣2762. 不间断子数组

力扣2762. 不间断子数组

multiset法

  • multiset:元素从小到大排序

    • begin()返回头指针 (最小)
    • rbegin()返回尾指针 (最大)
cpp 复制代码
  class Solution {
  public:
      long long continuousSubarrays(vector<int>& nums) {
          int n = nums.size();
          long long res = 0;
          multiset<int> s;
          for(int i=0,j=0;i<n;i++)
          {   
              s.insert(nums[i]);
              while(*s.rbegin() - *s.begin() > 2)
              {
                  s.erase(s.find(nums[j++]));
              }
              res += i-j+1;
          }
          return res;
      }
  };

哈希表法

  • map:记录出现次数

    • 同样的rbegin和begin
cpp 复制代码
  class Solution {
  public:
      long long continuousSubarrays(vector<int>& nums) {
          int n = nums.size();
          long long res = 0;
          map<int,int> cnt;
          for(int i=0,j=0;i<n;i++)
          {   
              cnt[nums[i]] ++;
              while(cnt.rbegin()->first - cnt.begin()->first > 2)
              {
                  if(-- cnt[nums[j]] == 0) cnt.erase(nums[j++]);
              }
              res += i-j+1;
          }
          return res;
      }
  };
相关推荐
韧竹、12 分钟前
数据结构之单链表
数据结构·链表
And_Ii13 分钟前
LeetCode 3350. 检测相邻递增子数组 II
数据结构·算法·leetcode
想唱rap16 分钟前
C++ string类的使用
开发语言·c++·笔记·算法·新浪微博
JAVA学习通16 分钟前
Replication(下):事务,一致性与共识
大数据·分布式·算法
胖咕噜的稞达鸭17 分钟前
C++中的父继子承(2)多继承菱形继承问题,多继承指针偏移,继承组合分析+高质量习题扫尾继承多态
c语言·开发语言·数据结构·c++·算法·链表·c#
蓝色汪洋20 分钟前
Completed String easy
算法
铭哥的编程日记22 分钟前
贪心算法精选30道编程题 (附有图解和源码)
算法·贪心算法
CoovallyAIHub25 分钟前
顶刊新发!上海交大提出PreCM:即插即用的旋转等变卷积,显著提升分割模型鲁棒性
人工智能·算法·计算机视觉
超级大只老咪33 分钟前
哈希表(算法)
java·算法·哈希算法
冷月葬花~1 小时前
day24
数据结构·算法·leetcode