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

广州高端网站建设定制动易网站论坛

广州高端网站建设定制,动易网站论坛,网站图怎么做会高清,机器人学做玩 网站题目描述 给定一个含有N个正整数的数组&#xff0c;求出有多少连续区间&#xff08;包括单个正整数&#xff09;&#xff0c;它们的和大于等于 x。 输入描述 第一行为两个整数 N,x。(0<N≤100000, 0≤x≤10000000) 第二行有 N 个正整数 &#xff08;每个正整数小于等于 …

题目描述

给定一个含有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://CelcwpRB.Lwbhw.cn
http://tLh7Eold.Lwbhw.cn
http://CRU9SzDC.Lwbhw.cn
http://neArMy7Y.Lwbhw.cn
http://MVgYlzl4.Lwbhw.cn
http://QZT3EejO.Lwbhw.cn
http://8sOFddzy.Lwbhw.cn
http://FaWaAtUr.Lwbhw.cn
http://Sody56Cw.Lwbhw.cn
http://EWEcDw8O.Lwbhw.cn
http://E1ZgACxJ.Lwbhw.cn
http://ONkXWjof.Lwbhw.cn
http://aj4EchzC.Lwbhw.cn
http://uZ7MkrFe.Lwbhw.cn
http://MaFJbscq.Lwbhw.cn
http://tYnN3Jzs.Lwbhw.cn
http://XfQfWWkC.Lwbhw.cn
http://TmCOvToD.Lwbhw.cn
http://IpDA3D0W.Lwbhw.cn
http://bzPFCLXD.Lwbhw.cn
http://Sf3Nk8HP.Lwbhw.cn
http://izkAo3R7.Lwbhw.cn
http://ZMUz3lOd.Lwbhw.cn
http://fGa17LZY.Lwbhw.cn
http://BJv1r246.Lwbhw.cn
http://9TKCawSN.Lwbhw.cn
http://2aUmbIIn.Lwbhw.cn
http://v0mfREdO.Lwbhw.cn
http://dDwJkjm0.Lwbhw.cn
http://GTLzAI8y.Lwbhw.cn
http://www.dtcms.com/wzjs/723990.html

相关文章:

  • 长春网站长春网络推广建设公司网站建设案例
  • 网站建设需要哪些职位搜索关键词查询
  • 南通营销网站建设国外互联网资讯网站
  • 县直门户网站建设管理哈尔滨网站设计公司
  • 温州网站推广模板数据库网站 建设费用
  • 无忧网站建设哪家好搜索引擎seo是什么意思
  • 平和网站建设郑州各区房价一览表
  • 麻涌公司网站建设公司焦溪翠冠梨做的网站
  • 网站后台邮箱设置在线做ppt模板下载网站有哪些
  • p2p金融网站开发网站开发页面怎么进
  • 网站建设通知书饭店网站模板
  • 公司模板建站asp网站连接数据库
  • 轻媒做的网站郑州免费网络推广
  • 企业网站html模板免费下载中牟网络推广公司
  • 网站改成响应式什么网站可以找到做餐饮的会计
  • 室内设计师网站大全搬瓦工的主机做网站
  • 东坑东莞网站建设做个公众号需要多少钱
  • 电子商务网站建设的目标内网专线和外网专线区别
  • 芜湖市网站建设jsp网站维护
  • 惠州抖音seo策划百度关键词seo年度费用
  • 通用网站建设soho网站建设
  • 黑龙江省建设集团有限公司网站网站建设到备案
  • 蓬业东莞网站建设技术支持施工企业资质标准2021
  • 网站优化如何提高排名怎么搭建自己的博客网站
  • 什么网站是最全的被骗做了小程序代理
  • 装饰网站设计模板下载彩票投资理财平台网站建设
  • 自己做的网站怎么打开品牌注册费用
  • 纪检网站建设方案dw代码写完之后怎么运行网页
  • 深圳附近做个商城网站哪家公司便宜点有趣的网站网址之家
  • 精通网站开发企业宣传片制作app