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)
相关推荐
eyexin20181 小时前
大模型量化与剪枝
算法·机器学习·剪枝
普通网友2 小时前
C# 中委托和事件的深度剖析与应用场景
java·算法·c#
安全系统学习2 小时前
网络安全之任意文件读取利用
算法·安全·web安全·网络安全·哈希算法
电院工程师2 小时前
2.4 Python基础概念:通过一个文字冒险游戏学习编程
开发语言·python·学习·算法·游戏·游戏程序
没故事的燕同学2 小时前
[GESP202306 三级] 密码合规
算法
钢铁男儿3 小时前
C#数组完全指南:从基础到多维数组解析
数据结构·算法
黑听人3 小时前
【力扣 C】力扣刷题目录
c语言·leetcode
豆沙沙包?3 小时前
2025年- H82-Lc190--322.零钱兑换(动态规划)--Java版
java·算法·动态规划
Coovally AI模型快速验证4 小时前
数据集分享 | 电力检测数据集,助力AI守护电网安全
人工智能·算法·安全·计算机视觉·目标跟踪
IT古董4 小时前
【第二章:机器学习与神经网络概述】01.聚类算法理论与实践-(1)K-means聚类算法
人工智能·算法·聚类