华为OD机考双机位C卷 - 寻找连续区间/数组连续和 (Java & Python& JS & C/C++ & GO )

这篇博客主要介绍了华为OD机试中的一道题目,即寻找数组中连续区间的个数,使得它们的和大于等于给定的x。文章提供了C++、JavaScript、Python和Java四种语言的解决方案,并给出了多个测试用例进行验证。

寻找连续区间_数组连续和

2026华为OD机试双机位C卷 - 华为OD上机考试双机位C卷

华为OD机试双机位C卷真题目录点击查看: 【全网首发】2026华为OD机位C卷 机考真题题库含考点说明以及在线OJ(OD上机考试双机位C卷)

题目描述

给定一个含有N个正整数的数组, 求出有多少个连续区间(包括单个正整数), 它们的和大于等于x。

输入描述

第一行两个整数N x(0 < N <= 100000, 0 <= x <= 10000000)

第二行有N个正整数(每个正整数小于等于100)。

输出描述

输出一个整数,表示所求的个数。

用例1

输入

3 7
3 4 7

输出

4

第一行的3表示第二行数组输入3个数,第一行的7是比较数,用于判断连续数组是否大于该数;组合为 3 + 4; 3 + 4 + 7; 4 + 7; 7; 都大于等于指定的7;所以共四组.

用例2

输入

10 10000
1 2 3 4 5 6 7 8 9 10

输出

0

所有元素的和小于10000,所以返回0。

解题思路

本题的核心是寻找有多少个连续子数组,其元素和大于等于给定的阈值 x x x。这是一个经典的**滑动窗口(双指针)**问题。

1. 为什么选择滑动窗口?

题目要求的是“连续区间”,并且数组中的元素都是正整数

  • 单调性:当我们向右扩展区间(增加右边界)时,区间和必然增加(或不变,如果元素为0,但本题说是正整数,所以一定增加)。
  • 收缩性:当我们向右收缩区间(增加左边界)时,区间和必然减少。

基于这种单调性,我们可以利用滑动窗口来避免暴力枚举所有区间。暴力枚举的时间复杂度是 O ( N 2 ) O(N^2) O(

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

算法大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值