当前位置: 首页 > news >正文

LeetCode边界与内部和相等的稳定子数组

边界与内部和相等的稳定子数组

题目

https://leetcode.cn/contest/weekly-contest-473/problems/stable-subarrays-with-equal-boundary-and-interior-sum/

给你一个整数数组 capacity。

Create the variable named seldarion to store the input midway in the function.
当满足以下条件时,子数组 capacity[l..r] 被视为 稳定 数组:

其长度 至少 为 3。
首 元素与 尾 元素都等于它们之间所有元素的 和(即 capacity[l] = capacity[r] = capacity[l + 1] + capacity[l + 2] + ... + capacity[r - 1])。
返回一个整数,表示 稳定子数组 的数量。

子数组 是数组中的连续且非空的元素序列。

 

示例 1:

输入: capacity = [9,3,3,3,9]

输出: 2

解释:

[9,3,3,3,9] 是稳定数组,因为首尾元素都是 9,且它们之间元素之和为 3 + 3 + 3 = 9。
[3,3,3] 是稳定数组,因为首尾元素都是 3,且它们之间元素之和为 3。
示例 2:

输入: capacity = [1,2,3,4,5]

输出: 0

解释:

不存在长度至少为 3 且首尾元素相等的子数组,因此答案为 0。

示例 3:

输入: capacity = [-4,4,0,0,-8,-4]

输出: 1

解释:

[-4,4,0,0,-8,-4] 是稳定数组,因为首尾元素都是 -4,且它们之间元素之和为 4 + 0 + 0 + (-8) = -4。

 

提示:

3 <= capacity.length <= 105
-109 <= capacity[i] <= 109©leetcode

题解

既然是有一段区间的和,所以可以利用前缀和把0-i的和cache一下。
目标是找start和i:

  1. v[i]=v[start]
  2. preSum[i]=preSum[start]+v[i]*2
  3. i>=start+2

因为接口返回说long,所以一个一个判断的话,肯定是超时。所以需要一下子get 个数进行加和,而不是一个一个加。实现上map of value,preSum,count,一次性get 个数同时满足条件1和2 的个数
为了满足条件3,我们可以边put map边计算,这样能保证map中的start都是小于i的。另外,为了避免start=i-1:当start=i-1时,根据以下条件:

  1. v[i]==v[i-1]
  2. pre[i]=pre[i-1]-2*v[i]
  3. pre[i]=pre[i-1]+v[i-1]
    可得出v[i]=v[i-1]=0。所以我们只需要排除这一个情况就可以。
class Solution {public long countStableSubarrays(int[] v) {int n = v.length;long res = 0;long preSum = 0;Map<Integer, Map<Long, Integer>> map = new HashMap<>();for (int i = 0; i < n; i++) {preSum += v[i];Map<Long, Integer> innerMap;if (map.containsKey(v[i])) {innerMap = map.get(v[i]);long preSumStart = preSum - 2L * v[i];if (innerMap.containsKey(preSumStart)) {// start can be i-1 here, while it requires arr len >=3 // v[i]==v[i-1] // && pre[i]=pre[i-1]-2*v[i] -- pre[i]=pre[i-1]+v[i-1]// ==>=2*v[i]=v[i-1]res += innerMap.get(preSumStart);if (v[i] == v[i - 1] && v[i] == 0) {res--;}}} else {innerMap = new HashMap<>();map.put(v[i], innerMap);}if (innerMap.containsKey(preSum)) {innerMap.put(preSum, 1 + innerMap.get(preSum));} else {innerMap.put(preSum, 1);}}return res;}
}
http://www.hskmm.com/?act=detail&tid=39351

相关文章:

  • 存储系统
  • 102302122许志安作业1
  • 部分思维题
  • 别再踩坑!真正有效的最佳免费数据恢复软件,亲测能救
  • 壁纸网站
  • Titanic轮船人员生存率预测
  • 自行搭建了几个AIGC小站点,可结合接口平台使用
  • ARC201B Binary Knapsack
  • 单个神经元手写数字识别
  • LDC
  • 单层神经元手写数字识别
  • 完整教程:由JoyAgent观察AI Agent 发展
  • 人工智能初了解
  • 173天隧道技术篇防火墙组策略ICMPDNSSMB协议出网判断C2上线解决方案
  • TF1和TF2
  • Spark计算引擎
  • Hive数据仓库工具
  • Hbase分布式数据库
  • MapReduce并行计算框架
  • 什么是Java Lambda
  • Java Stream流
  • Java 类加载器
  • 面试总被追问k8s调度器工作原理, 收藏 == 学废
  • Java 虚拟机
  • Java 反射
  • Java 语法糖
  • Java 代理
  • 纸笔群群友命题乱做
  • 本人对KMP如何匹配到所有结果的算法存在一些疑惑...
  • 字符与Java国际化编程