【LeetCode】Day189-区间子数组个数
创始人
2024-02-12 01:44:12

题目

795. 区间子数组个数【中等】

题解

注意题目中说的是 子数组的最大值在 [left,right] 区间就行,翻译一下就是子数组中不能有超过right的元素,且至少有一个元素在 [left,right] 区间内

一次遍历

维护两个变量
last1:目标区间元素最后一次出现的位置
last2:非目标区间元素最后一次出现的位置
如果last1存在,则结果+=last1-last2

class Solution {public int numSubarrayBoundedMax(int[] nums, int left, int right) {int n=nums.length,res=0,last1=-1,last2=-1;for(int i=0;iif(nums[i]>=left&&nums[i]<=right)last1=i;//目标区间元素最后一次出现的位置else if(nums[i]>right){last2=i;//非目标区间元素最后一次出现的位置last1=-1;//标记此轮跳过res更新}if(last1!=-1)res+=last1-last2;}return res;}
}

时间复杂度:O(n)O(n)O(n)

空间复杂度:O(1)O(1)O(1)

计数

[…,right]-[…,left-1],两个区间元素个数相减,得到[left,right]区间的元素个数

class Solution {public int numSubarrayBoundedMax(int[] nums, int left, int right) {return count(nums,right)-count(nums,left-1);}public int count(int[] nums,int lower){int cur=0,res=0;for(int x:nums){cur=x<=lower?cur+1:0;//i左侧有多少个连续的元素<=lowerres+=cur;}return res;}
}

时间复杂度:O(n)O(n)O(n)

空间复杂度:O(1)O(1)O(1)

相关内容

热门资讯

中光学聘任61岁刘洋为非独立董... 6月18日,中光学公告,聘任刘洋先生为公司非独立董事。资料显示,刘洋,男,1965年出生,中国国籍,...
丽尚国潮股东杭州骥瑜商业管理有... 6月18日消息,丽尚国潮股东杭州骥瑜商业管理有限公司于2026年6月16日,通过大宗交易方式减持15...
国盛证券总经理赵景亮新任董事,... 6月18日,国盛证券公告,聘任赵景亮先生为公司董事。资料显示,赵景亮先生,1978年12月出生,特许...
成人超重率超三成 我国肥胖形势... (来源:千龙网)新华社北京6月17日电 当前我国成人超重率约为34.3%,肥胖率约为16.4%;6岁...
卢浮宫馆长称该博物馆已“不堪重... (来源:千龙网)新华社巴黎6月17日电 法国卢浮宫博物馆馆长克里斯托夫·勒里博17日就博物馆内设施设...