Leetcode-930. 和相同的二元子数组

Problem: 930. 和相同的二元子数组

思路

滑动窗口

解题过程

我们可以通过计算 和大于等于 goal 的子数组数目和大于等于 goal+1 的子数组数目差值,来得到 和恰好等于 goal 的子数组数目。

Code

c++

cpp 复制代码
class Solution {
public:
    int at_most(vector<int>& nums, int goal) {
        int ans = 0;
        int n = nums.size();
        int l = 0;
        int sum = 0;
        for(int r = 0; r < n; r ++){
            sum += nums[r];
            while(sum >= goal && l <=r){
                sum -= nums[l];
                l++;
            }
            ans += l;
        }
        return ans;
    }
    int numSubarraysWithSum(vector<int>& nums, int goal) {
        return at_most(nums, goal) - at_most(nums,goal+1);
    }
};

python

python 复制代码
class Solution:

    def numSubarraysWithSum(self, nums: List[int], goal: int) -> int:
        def at_most(goal):
            ans = 0
            n = len(nums)
            l = 0
            sum = 0
            for r, x in enumerate(nums):
                sum += x
                while sum >= goal and l <= r:
                    sum -= nums[l]
                    l += 1
                ans += l
            return ans

        return at_most(goal) - at_most(goal + 1)

复杂度

  • 时间复杂度: O(n)O(n) O(n)
  • 空间复杂度: O(1)O(1) O(1)
相关推荐
沐苏瑶1 小时前
Java 搜索型数据结构全解:二叉搜索树、Map/Set 体系与哈希表
java·数据结构·算法
ZoeJoy82 小时前
算法筑基(二):搜索算法——从线性查找到图搜索,精准定位数据
算法·哈希算法·图搜索算法
Alicx.2 小时前
dfs由易到难
算法·蓝桥杯·宽度优先
_日拱一卒2 小时前
LeetCode:找到字符串中的所有字母异位词
算法·leetcode
云泽8083 小时前
深入 AVL 树:原理剖析、旋转算法与性能评估
数据结构·c++·算法
Wilber的技术分享4 小时前
【LeetCode高频手撕题 2】面试中常见的手撕算法题(小红书)
笔记·算法·leetcode·面试
邪神与厨二病4 小时前
Problem L. ZZUPC
c++·数学·算法·前缀和
梯度下降中5 小时前
LoRA原理精讲
人工智能·算法·机器学习
IronMurphy5 小时前
【算法三十一】46. 全排列
算法·leetcode·职场和发展
czlczl200209255 小时前
力扣1911. 最大交替子序列和
算法·leetcode·动态规划