LeetCode 3737.统计主要元素子数组数目 I:枚举+计数
【LetMeFly】3737.统计主要元素子数组数目 I:枚举+计数
力扣题目链接:https://leetcode.cn/problems/count-subarrays-with-majority-element-i/
给你一个整数数组nums和一个整数target。
返回数组nums中满足target是主要元素的子数组的数目。
一个子数组的主要元素是指该元素在该子数组中出现的次数严格大于其长度的一半。
子数组是数组中的一段连续且非空的元素序列。
示例 1:
输入:nums = [1,2,2,3], target = 2
输出:5
解释:
以target = 2为主要元素的子数组有:
nums[1..1] = [2]nums[2..2] = [2]nums[1..2] = [2,2]nums[0..2] = [1,2,2]nums[1..3] = [2,2,3]
因此共有 5 个这样的子数组。
示例 2:
输入:nums = [1,1,1,1], target = 1
输出:10
解释:
所有 10 个子数组都以 1 为主要元素。
示例 3:
输入:nums = [1,2,3], target = 4
输出:0
解释:
target = 4完全没有出现在nums中。因此,不可能有任何以 4 为主要元素的子数组。故答案为 0。
提示:
1 <= nums.length <= 10001 <= nums[i] <= 1091 <= target <= 109
解题方法:枚举 + 计数
二重循环枚举所有子数组(第一层循环枚举数组起点、第二层循环枚举数组终点),在第二层循环开始前使用一个变量记录这个数组中共计出现了多少个target。如果target出现数量乘以2大于数组长度,则答案数量加一。
- 时间复杂度O ( l e n ( n u m s ) 2 ) O(len(nums)^2)O(len(nums)2)
- 空间复杂度O ( 1 ) O(1)O(1)
AC代码
C++
/* * @LastEditTime: 2026-06-25 22:09:54 */classSolution{public:intcountMajoritySubarrays(vector<int>&nums,inttarget){intans=0;for(inti=0,n=nums.size();i<n;i++){intcnt=0;for(intj=i;j<n;j++){cnt+=nums[j]==target;ans+=cnt*2>j-i+1;}}returnans;}};同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~
千篇源码题解已开源
