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

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

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

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$。这是一个经典的滑动窗口(双指针)问题。

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

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

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

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

2. 算法逻辑

我们维护一个窗口 [left, right],以及该窗口内元素的和 sum

  1. 初始化leftright 都指向数组开头,sum 为 0,count 为 0。
  2. 右移窗口:不断增加 right,将 nums[right] 加入 sum
  3. 判断与收缩
    • sum >= x 时,说明当前从 leftright 的区间满足条件。
    • 关键点:如果 nums[left...right] 的和已经 $\ge x$,那么对于同一个 left,任何比 right 更大的右边界 right'(即 nums[left...right'])也一定满足和 $\ge x$(因为元素都是正数)。
    • 因此,对于当前的 left,满足条件的区间有 n - right 个(即 [left, right], [left, right+1], ..., [left, n-1])。
    • 累加这个数量到 count
    • 为了寻找下一个满足条件的最小窗口,我们需要收缩左边界:从 sum 中减去 nums[left],并将 left 加 1。
    • 重复上述判断,直到 sum < x,此时我们需要继续增加 right 来扩大窗口。
  4. 循环结束:当 right 遍历完数组后,输出 count

3. 举例说明

假设数组为 [3, 4, 7],目标 $x=7$。

  • right=0 (3), sum=3 (<7),继续。
  • right=1 (4), sum=3+4=7 (>=7):
    • 满足条件!当前区间 [3, 4]
    • 3 开头且右边界 $\ge 1$ 的区间有:[3, 4], [3, 4, 7]。共 3 - 1 = 2 个。
    • count += 2
    • 收缩左边界:sum -= 3 (变4),left 变 1。
  • 检查 sum=4 (<7),继续增加 right
  • right=2 (7), sum=4+7=11 (>=7):
    • 满足条件!当前区间 [4, 7]
    • 4 开头且右边界 $\ge 2$ 的区间有:[4, 7]。共 3 - 2 = 1 个。
    • count += 1
    • 收缩左边界:sum -= 4 (变7),left 变 2。
  • 检查 sum=7 (>=7):
    • 满足条件!当前区间 [7]
    • 7 开头且右边界 $\ge 2$ 的区间有:[7]。共 3 - 2 = 1 个。
    • count += 1
    • 收缩左边界:sum -= 7 (变0),left 变 3。
  • right 结束。
  • 总数 2 + 1 + 1 = 4
http://www.jsqmd.com/news/435069/

相关文章:

  • 分析上海靠谱的ISO认证机构,推荐几家诚信专业的公司 - 工业推荐榜
  • Editor Profile陷阱:别让医院噪音误诊你的游戏
  • 航空航天项目如何用Java保障卫星数据文件的分片上传下载完整性?
  • 还在为文档时间不对烦恼?这4招让你秒改创建和修改时间
  • 百度文库如何修改已上传的文档?
  • 学长亲荐!AI论文软件 千笔AI VS 云笔AI,自考写论文神器!
  • 百度文库的上传时间?这个时间可以修改吗?
  • 全屋定制品牌哪家强?2026年杭州品牌推荐与评价,解决服务流程与交付延期痛点 - 品牌推荐
  • 修改excel创建时间和修改时间的方法分享给你
  • 吐血推荐!千笔·降AI率助手,深得人心的降AIGC软件
  • 2026年西安全屋定制品牌推荐:基于多场景实测评价,解决环保与交付痛点并附排名 - 品牌推荐
  • 如何把word的创建时间和修改时间改成当前时间?这几个方法很好用
  • 聊聊济南腾昕全屋定制,价格贵不贵,选购时要注意什么? - 工业设备
  • 乌海电动伸缩门厂家解析|行业现状解析+源头厂家,避坑全攻略 - 宁夏壹山网络
  • 2026年西安全屋定制品牌推荐:高端住宅深度评测,针对安装精度与设计痛点精准指南 - 品牌推荐
  • 共话2026年规模大的氧化铝陶瓷生产厂家,北京地区价格多少钱 - 工业品网
  • 2026年杭州全屋定制品牌推荐:家居定制趋势评测,涵盖美学体验与功能适配核心痛点 - 品牌推荐
  • 20260304网络浏览记录
  • 探讨理优清北教育,学习规划科学吗推荐哈尔滨考生选择吗 - mypinpai
  • 分析2026年淮南服务不错的对口升学培训学校,如何选择合适的 - myqiye
  • 闲置分某乐京东e卡回收方式推荐指南 - 京顺回收
  • 如何为不同住宅选定制品牌?2026年上海全屋定制全面评测与推荐,直击环保与交付痛点 - 品牌推荐
  • 全屋定制哪个品牌好?2026年重庆全屋定制推荐与排名,解决个性化与工艺核心痛点 - 品牌推荐
  • 市面上优质电子压床供应商排行(2026年版),别错过,伺服压装机/伺服电子压力机/伺服油压机,电子压床厂家排行榜 - 品牌推荐师
  • 如何选择适配高端楼盘的全屋定制?2026年杭州品牌推荐与评价,直击服务痛点 - 品牌推荐
  • 不踩雷! 8个AI论文网站测评:MBA毕业论文写作必备工具推荐
  • 全屋定制品牌哪家强?2026年上海全屋定制推荐与评测,解决品质稳定性与售后痛点 - 品牌推荐
  • 中雅乐石英石按需定制价格贵不贵,对比其他品牌性价比高吗? - 工业设备
  • 2026年杭州全屋定制品牌推荐:基于多楼盘案例评价,针对高净值人群定制痛点精准指南 - 品牌推荐
  • 2026年重庆全屋定制品牌推荐:智能高定趋势评测,涵盖大宅与改善场景品质痛点 - 品牌推荐