力扣2444.统计定界子数组的数目

力扣2444.统计定界子数组的数目

  • 观察到不满足条件的数 可以作为天然的分割线

    • 因此在枚举右端点的过程中 预处理minK,maxK和分割线上一次出现的下标

    • res += min(min_i,max_i) - i0;

    • 但是因为可能在到下个区段时 min_i和max_i尚未更新 导致结果为负数

    • 所以要跟0再取一个max

    • res += max(min(min_i,max_i)-i0,0)

  • 方便计算

    • 初始化i0 = -1;
cpp 复制代码
  class Solution {
  public:
      long long countSubarrays(vector<int>& nums, int minK, int maxK) {
          long long res=0;
          int n = nums.size(),min_i = -1,max_i = -1,i0 = -1;
          for(int i=0;i<n;i++)
          {
              int x = nums[i];
              if(x == minK) min_i = i;
              if(x == maxK) max_i = i;
              if(x < minK || x > maxK) i0 = i;
              res += max(min(min_i,max_i)-i0,0);
          }
          return res;
      }
  };
相关推荐
aini_lovee4 分钟前
严格耦合波(RCWA)方法计算麦克斯韦方程数值解的MATLAB实现
数据结构·算法·matlab
安特尼20 分钟前
推荐算法手撕集合(持续更新)
人工智能·算法·机器学习·推荐算法
weixin_4572971023 分钟前
大数据面试常见问题
大数据·面试·职场和发展
鹿角片ljp27 分钟前
力扣14.最长公共前缀-纵向扫描法
java·算法·leetcode
Remember_99331 分钟前
【数据结构】深入理解优先级队列与堆:从原理到应用
java·数据结构·算法·spring·leetcode·maven·哈希算法
偷星星的贼1132 分钟前
C++中的状态机实现
开发语言·c++·算法
程序员敲代码吗33 分钟前
C++中的组合模式实战
开发语言·c++·算法
52Hz1181 小时前
二叉树理论、力扣94.二叉树的中序遍历、104.二叉树的最大深度、226.反转二叉树、101.对称二叉树
python·算法·leetcode
Shirley~~1 小时前
leetcode移除元素
javascript·数据结构·算法
普贤莲花1 小时前
新生2026年1月20日---星期二(大寒)
程序人生·算法·leetcode