在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中文网其他相关文章!

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

我们有两个整数数组,一个具有计算的元素,另一个具有分割数组以生成子集所需的分割点,我们必须计算每个分割中每个子集的总和并返回最大子集让我们通过示例来理解:-输入−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++解决寻找最大值和最小值相同的子数组数量的问题。以下是该问题的示例−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的和的子数组的数量。在这个问题中,我们有一个数组arr[]和一个整数K。现在我们需要找出和小于K的子数组。以下是示例−Input:arr[]={1,11,2,3,15}K=10Output:4{1},{2},{3}and{2,3}寻找解决方案的方法现在我们将使用两种不同的方法来解决给定的问题-暴力破解在这种方法中,我们将迭代遍历所有子数组并计算它们的总和,如果总和小于k,则与k进行比较,以增加我们的答案。示例#include<

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

子数组是数组的连续部分。例如,我们考虑一个数组[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

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

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

在本文中,我们将描述查找子数组中素数数量的方法。我们有一个正数数组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
