目录
让我们通过示例来理解:-
以下程序中使用的方法是如下 -
示例
输出
首页 Java java教程 在Java中,将数组分割为基于给定查询的子数组后,找到子数组的最大子数组和

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

Aug 29, 2023 am 11:21 AM
子数组 数组分割 最大子数组和

在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

第二次分割后 → {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() 方法开始

    • 输入数组任何给定长度,例如 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<subSets>{
   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<Integer> t1 = new TreeSet<>();
      TreeSet<subSets> 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中,将数组分割为基于给定查询的子数组后,找到子数组的最大子数组和的详细内容。更多信息请关注PHP中文网其他相关文章!

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

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

在Java中,将数组分割为基于给定查询的子数组后,找到子数组的最大子数组和 在Java中,将数组分割为基于给定查询的子数组后,找到子数组的最大子数组和 Aug 29, 2023 am 11:21 AM

我们有两个整数数组,一个具有计算的元素,另一个具有分割数组以生成子集所需的分割点,我们必须计算每个分割中每个子集的总和并返回最大子集让我们通过示例来理解:-输入−intarr[]=intarr[]={9,4,5,6,7}intsplitPoints[]={0,2,3,1};输出−每次分割后的最大子数组和[22,13,9,9]解释−这里我们根据数组的分割点来分解数组,并在每次分割后获得最大子集和第一次分割后→{9}和{4,5,6,7}>>最大子数组总和为-22第二次分割后→{9},{4

使用C++编写代码,找到具有相同最小值和最大值的子数组的数量 使用C++编写代码,找到具有相同最小值和最大值的子数组的数量 Aug 25, 2023 pm 11:33 PM

在本文中,我们将使用C++解决寻找最大值和最小值相同的子数组数量的问题。以下是该问题的示例−Input:array={2,3,6,6,2,4,4,4}Output:12Explanation:{2},{3},{6},{6},{2},{4},{4},{4},{6,6},{4,4},{4,4}and{4,4,4}arethesubarrayswhichcanbeformedwithmaximumandminimumelementsame.Input:array={3,3,1,5,

使用C++编写,找到和小于K的子数组的数量 使用C++编写,找到和小于K的子数组的数量 Sep 07, 2023 pm 03:25 PM

在这篇文章中,我们将使用C++找出具有小于K的和的子数组的数量。在这个问题中,我们有一个数组arr[]和一个整数K。现在我们需要找出和小于K的子数组。以下是示例−Input:arr[]={1,11,2,3,15}K=10Output:4{1},{2},{3}and{2,3}寻找解决方案的方法现在我们将使用两种不同的方法来解决给定的问题-暴力破解在这种方法中,我们将迭代遍历所有子数组并计算它们的总和,如果总和小于k,则与k进行比较,以增加我们的答案。示例#include<

在C++中,最大化具有零XOR的子数组的数量 在C++中,最大化具有零XOR的子数组的数量 Aug 28, 2023 pm 09:05 PM

我们得到一个包含整数值的数组Arr[]。目标是找到XOR为0的子数组的最大数量。任何子数组的位都可以交换任意次数。注意:-1

使用C++编写代码,找到具有奇数和的子数组的数量 使用C++编写代码,找到具有奇数和的子数组的数量 Sep 21, 2023 am 08:45 AM

子数组是数组的连续部分。例如,我们考虑一个数组[5,6,7,8],那么有十个非空子数组,如(5),(6),(7),(8),(5,6),(6,7)、(7,8)、(5,6,7)、(6,7,8)和(5,6,7,8)。在本指南中,我们将解释在C++中查找所有可能的信息来查找具有奇数和的子数组的数量。为了找到奇数和的子数组的数量,我们可以使用不同的方法,所以这里是一个简单的例子-Input:array={9,8,7,6,5}Output:9Explanation:Sumofsubarray-{9}=9{7

最长的子数组,其最大公约数大于1 最长的子数组,其最大公约数大于1 Sep 18, 2023 pm 10:17 PM

数组是一组相似的数据集合,以连续的方式存储在相邻的内存位置上。通过将偏移值定义为数据库的特定基值,可以更容易地评估每个元素的特定位置。该特定索引的基值为零,偏移值是两个特定索引之间的差值。子数组是特定数组的一部分,可以定义为一组变量,具有多个值的标签。最长的子数组指的是数组中所有元素都大于K的数组。这里最大和子数组的和为-给定数据集中的少于等于给定的数据集。给定数据集中的少于要找到最长子数组的长度,我们只需要找出特定子数组中1的总数。注意:计数应该大于零的计数。最大公约数是一种数学现象,在其中我

PHP 数组如何合并和分割 PHP 数组如何合并和分割 Sep 05, 2023 am 08:47 AM

PHP数组是一种非常常用的数据结构,在开发中经常涉及到对数组的合并和分割操作。本文将介绍如何使用PHP语言实现这两种操作,并附上相应的代码示例。一、合并数组合并数组的操作可以使用array_merge()函数来实现。该函数接受多个数组作为参数,并将它们合并成一个新的数组。代码示例:$array1=["apple","ba

使用C++编写,找到子数组中的质数数量 使用C++编写,找到子数组中的质数数量 Sep 01, 2023 am 08:37 AM

在本文中,我们将描述查找子数组中素数数量的方法。我们有一个正数数组arr[]和q个查询,其中有两个整数表示我们的范围{l,R},我们需要找到给定范围内的素数数量。下面是给定问题的示例-Input:arr[]={1,2,3,4,5,6},q=1,L=0,R=3Output:2Inthegivenrangetheprimesare{2,3}.Input:arr[]={2,3,5,8,12,11},q=1,L=0,R=5Output:4Inthegivenrangetheprimesare{2,3,5

See all articles