力扣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;
      }
  };
相关推荐
workflower28 分钟前
用硬件换时间”与“用算法降成本”之间的博弈
人工智能·算法·安全·集成测试·无人机·ai编程
重生之我是Java开发战士2 小时前
【动态规划】简单多状态dp问题:按摩师,打家劫舍,删除并获得点数,粉刷房子,买卖股票的最佳时机
算法·动态规划·哈希算法
KAU的云实验台3 小时前
单/多UAV、静/动态路径规划,基于PlatEMO平台的带约束多目标优化 本文核心内容:
算法·matlab·无人机
Liangwei Lin3 小时前
洛谷 P1807 最长路
数据结构·算法
会编程的土豆3 小时前
【数据结构与算法】二叉树从建立开始
数据结构·c++·算法
_日拱一卒3 小时前
LeetCode:最大子数组和
数据结构·算法·leetcode
计算机安禾4 小时前
【数据结构与算法】第22篇:线索二叉树(Threaded Binary Tree)
c语言·开发语言·数据结构·学习·算法·链表·visual studio code
算法鑫探4 小时前
解密2025数字密码:数位统计之谜
c语言·数据结构·算法·新人首发
计算机安禾4 小时前
【数据结构与算法】第21篇:二叉树遍历的经典问题:由遍历序列重构二叉树
c语言·数据结构·学习·算法·重构·visual studio code·visual studio