数组连续和 - 华为OD统一考试(C卷)

devtools/2025/3/25 13:56:55/

题目描述

给定一个含有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。

 Java代码

第一种暴力法,时间复杂度O(n^2)

package odTest;import java.util.Arrays;
import java.util.Scanner;public class continueArraySum {static int count = 0;public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int[] condtions = Arrays.stream(scanner.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();int[] numArrays = Arrays.stream(scanner.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray();int count = 0;for(int i=0;i<condtions[0];i++) {int sum = 0;for(int j=i;j<condtions[0];j++) {sum = sum +numArrays[j];if(sum>=condtions[1]) {count++;}}}System.out.println(count);}
}

 第二种双指针法

将下标为1到最后下标之间所有和的情况都保存起来(n[0],n[0]+n[1],n[0]+n[1]+n[2]....),r然后通过r=1下标值减l=0下标值,当结果大于题目所给的限制值的时候,说明r=1下标后的所有都符合条件,然后 count += n-r+1,n为所给的数组长度。然后,r和l依次加1判断下一个连续区间符合条件的个数。

package odTest;import java.util.Scanner;public class continueArraySum1 {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt(); // 输入数组大小int x = scanner.nextInt(); // 输入目标值int[] arr = new int[n]; // 定义数组for (int i = 0; i < n; i++) {arr[i] = scanner.nextInt(); // 输入数组元素}System.out.println(getResult(n, x, arr)); // 调用函数并打印结果}// 获取结果的方法public static int getResult(int n, int x, int[] arr) {int[] preSum = new int[n + 1];//这一步保证从下表为0开始计算preSum[0] = 0;//将下标从 0-1,0-2,0-3,0-4....0-n的值保存到数组中for (int i = 1; i <= n; i++) {preSum[i] = preSum[i - 1] + arr[i - 1]; // 求前缀和}int l = 0;int r = 1;int ans = 0;while (r <= n) {//preSum[r] - preSum[l] 的值代表数组区间的和大小,大于给定的值时,//说明r后面的值累计都会大于给定的值,直接累计到ans就行了,否则r就往后移if (preSum[r] - preSum[l] >= x) {ans += n - r + 1; // 更新结果l++;r = l + 1;} else {r++;}}return ans; // 返回结果}
}


http://www.ppmy.cn/devtools/169233.html

相关文章

联想拯救者触摸板会每次开机都自动关闭、联想笔记本触摸板关闭、笔记本电脑触摸板自动关闭的解决方法

首先无硬性问题的话没有严重磕碰的话就不是外部受力问题 再看看驱动是否都正常更新了 再去看看是不是系统设置外接鼠标会自动关闭触摸板&#xff1f;触摸板也打开了功能也开了 最后只可能就是你的电脑某个关乎控制触摸板的软件导致的&#xff0c;没错就是联想自带的Legion Zone…

【Python】数据结构有Python版吗?

李升伟 整理 数据结构可以用Python实现。Python提供了多种内置数据结构&#xff0c;如列表&#xff08;list&#xff09;、元组&#xff08;tuple&#xff09;、集合&#xff08;set&#xff09;、字典&#xff08;dict&#xff09;等。此外&#xff0c;Python的标准库还包含一…

【USTC 计算机网络】第二章:应用层 - P2P、CDN

本文首先介绍了网络架构中的另一大模式&#xff1a;P2P&#xff0c;主要介绍了结构化 P2P 与非结构化 P2P&#xff0c;以及如何通过集中式目录或查询洪泛方法查找资源&#xff0c;接着介绍了流媒体传输技术 DASH 与内容分发网络 CDN&#xff0c;通过 CDN 能够实现快速、稳定、安…

【redis】在 Spring中操作 Redis

文章目录 基础设置依赖StringRedisTemplate库的封装 运行StringList删库 SetHashZset 基础设置 依赖 需要选择这个依赖 StringRedisTemplate // 后续 redis 测试的各种方法&#xff0c;都通过这个 Controller 提供的 http 接口来触发 RestController public class MyC…

3.21学习总结 Java字符串+Static关键字

this关键字&#xff1a; 作用&#xff1a;区别局部变量和成员变量 本质&#xff1a;所在方法调用者的地址值 就近原则 API StringBulider 使用场景&#xff1a;1.字符串的拼接&#xff0c;2.字符串的反转。 练习题&#xff1a; 链式编程&#xff1a; 在调用一个方法的时候…

【Bluebell】项目总结:基于 golang 的前后端分离 web 项目实战

文章目录 Bluebell 项目总结&#xff1a;基于 golang 的前后端分离 web 项目实战项目入口&#xff1a;先从 main 函数入手准备工作&#xff1a;加载配置、初始化日志、初始化数据库等加载配置初始化日志初始化 MySQL 连接初始化 Redis 连接初始化雪花算法初始化 GIN 框架内置的…

解释什么是受控组件和非受控组件

在 React 中&#xff0c;表单元素的管理和处理是一个重要的主题。理解受控组件和非受控组件之间的区别&#xff0c;对构建高效、可维护的用户界面至关重要。本文将深入探讨这两种组件的定义、优缺点、使用场景以及最佳实践。 1. 什么是受控组件&#xff1f; 1.1 定义 受控组…

无服务器架构将淘汰运维?2025年云计算形态预测

无服务器架构将淘汰运维&#xff1f;2025年云计算形态预测 随着云计算技术的快速演进&#xff0c;**无服务器架构&#xff08;Serverless&#xff09;**正逐步改变企业的开发与运维模式。无服务器架构是否会彻底淘汰传统运维&#xff1f;2025年的云计算格局将如何演变&#xf…