0

0

在Java中,将数组分割为基于给定查询的子数组后,找到子数组的最大子数组和

WBOY

WBOY

发布时间:2023-08-29 11:21:09

|

1070人浏览过

|

来源于tutorialspoint

转载

在java中,将数组分割为基于给定查询的子数组后,找到子数组的最大子数组和

我们有两个整数数组,一个具有计算的元素,另一个具有分割数组以生成子集所需的分割点,我们必须计算每个分割中每个子集的总和并返回最大子集

让我们通过示例来理解:-

输入− int arr[] = int arr[] = { 9, 4, 5, 6 , 7 } int splitPoints[] = { 0, 2, 3, 1 };

输出− 每次分割后的最大子数组和 [22, 13, 9, 9]

解释− 这里我们根据数组的分割点来分解数组,并在每次分割后获得最大子集和

第一次分割后 strong> → {9} 和 {4,5,6,7} >> 最大子数组总和为 - 22

立即学习Java免费学习笔记(深入)”;

第二次分割后 → {9}, {4,5 } 和 {6,7} >> 最大子数组和为 - 13

第三次分割后 →{9}、{4,5}、{6} 和 {7} >> 最大子数组和为 - 9

第四次分割后 →{9}、{4}、{5}、{6} 和 {7} >> 最大子数组和is- 9

输入−int arr[] = int arr[] = { 7, 8, 5, 9, 1 } int splitPoints[] = { 1, 2, 0, 3 };

输出−每次分割后的最大子数组和 [15, 115, 10, 9]

解释−这里我们根据数组的分割点来分解数组,并在每次分割后获得最大子集和

第一次分割后 → {7,8} 和 {5,9 ,1} >> 最大子数组和为 15

第二次分割后 → {7,8}、{5} 和 {9,1} >> 最大子数组和为 115

第三次分割后 →{7}、{8}、{5} 和 {9,1} >> 最大子数组总和为 10

第四次分割后 →{7}、{8}、{5}、{9} 和 {1} >> 最大子数组和为 9

以下程序中使用的方法是如下 -

  • 我们将从 main() 方法开始

    Noya
    Noya

    让线框图变成高保真设计。

    下载
    • 输入数组任何给定长度,例如 arr[] 和 splitPoints[]。计算它们的长度并以calculateSubsetSum(arr.length, splitPoints.length, splitPoints, arr)的形式传递给方法。

  • 在方法calculateSubsetSum中()

    • 创建一个整数数组作为 sum[],并将 sum[0] 设置为 arr[0]。

    • 开始循环 FOR 从 i 到 1 直到数组的长度,并将 sum[i] 设置为 sum[i - 1] + arr[i] 并将 temp[0] 设置为 new subSets(0, n - 1, sum[n - 1])。

    • 继续添加 t2.add(temp[0]) 和 t1.add(0)

    • 从 i 到 0 开始循环 FOR,直到 splitPoints 数组的长度。在循环内部将 currentSplitPoint 设置为 t1.floor(splitPoints[i]) 并从 t2 中删除为 t2.remove(temp[currentSplitPoint])

    • 将 end 设置为 temp[currentSplitPoint] .last 和 temp[currentSplitPoint] 作为新的 subSets(currentSplitPoint, splitPoints[i], sum[splitPoints[i]] - (currentSplitPoint == 0 ? 0 : sum[currentSplitPoint - 1]))

    • 使用 t2.add(temp[currentSplitPoint]) 和 temp[splitPoints[i] + 1] = new subSets(splitPoints[i] + 1, end, sum[end] - sum[splitPoints[i] 添加]])

    • 使用 t2.add(temp[splitPoints[i] + 1])、t1.add(currentSplitPoint) 和 t1.add(splitPoints[i] + 进行添加1)

    • 打印 t2.first() 值。

  • 创建一个类类 subSets 并声明first、last和value作为其数据成员,并将默认构造函数定义为subSets(int f, int l, int v),并将first设置为f,last设置为l,value设置为v

  • 创建一个类作为 utilityComparator,它将实现 Comparator

    • 创建一个公共方法作为比较并检查 IF s2.value 不等于到 s1.value,然后返回 s2.value - s1.value。

    • 检查 s1.first 是否不等于 s2.first,然后返回 s2.first - s1.first p>

示例

import java.io.IOException;
import java.io.InputStream;
import java.util.*;
class utilityComparator implements Comparator{
   public int compare(subSets s1, subSets s2){
      if(s2.value != s1.value){
         return s2.value - s1.value;
      }
      if(s1.first != s2.first){
         return s2.first - s1.first;
      }
      return 0;
   }
}
class subSets{
   int first;
   int last;
   int value;
   subSets(int f, int l, int v){
      first = f;
      last = l;
      value = v;
   }
}
public class testClass{
   static void calculateSubsetSum(int n, int k, int splitPoints[], int arr[]){
      int sum[] = new int[n];
      sum[0] = arr[0];
      for (int i = 1; i < n; i++){
         sum[i] = sum[i - 1] + arr[i];
      }
      TreeSet t1 = new TreeSet<>();
      TreeSet t2 = new TreeSet<>(new utilityComparator());
      subSets temp[] = new subSets[n];
      temp[0] = new subSets(0, n - 1, sum[n - 1]);
      t2.add(temp[0]);
      t1.add(0);
      System.out.println("Maximum subarray sum after each split");
      for (int i = 0; i < k; i++){
         int currentSplitPoint = t1.floor(splitPoints[i]);
         t2.remove(temp[currentSplitPoint]);
         int end = temp[currentSplitPoint].last;
         temp[currentSplitPoint] = new subSets(currentSplitPoint, splitPoints[i], sum[splitPoints[i]] - (currentSplitPoint == 0 ? 0 : sum[currentSplitPoint - 1]));
         t2.add(temp[currentSplitPoint]);
         temp[splitPoints[i] + 1] = new subSets(splitPoints[i] + 1, end, sum[end] -       sum[splitPoints[i]]);
         t2.add(temp[splitPoints[i] + 1]);
         t1.add(currentSplitPoint);
         t1.add(splitPoints[i] + 1);
         System.out.println(t2.first().value);
      }
   }
   public static void main(String[] args){
      int arr[] = { 2, 1, 6, 8, 5, 10, 21, 13};
      int splitPoints[] = { 3, 1, 2, 0, 4, 5 };
      calculateSubsetSum(arr.length, splitPoints.length, splitPoints, arr);
   }
}

输出

如果我们运行上面的代码,它将生成以下输出

Maximum subarray sum after each split
49
49
49
49
44
34

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

825

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

724

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

728

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

395

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

445

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

428

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16861

2023.08.03

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 2.6万人学习

Excel 教程
Excel 教程

共162课时 | 10.2万人学习

R 教程
R 教程

共45课时 | 4.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号