gpt4 book ai didi

java - 分而治之算法数组中的最大数量

转载 作者:行者123 更新时间:2023-12-02 00:56:25 26 4
gpt4 key购买 nike

我是分治算法的新手,需要构造一个算法来查找数组中的最大数字。下面是我的代码,我知道我需要将数组分为两部分,然后递归地找到每个部分中的最大值。然后,合并并找到两部分中最大的部分。下面是我的代码,我正在努力弄清楚如何递归调用函数来找到每个部分的最大值。

private static int problem(int[] histogram) {
int left = 0;
int right = histogram.length -1;
if (left == right){
return left;
}
int middle = (left + right)/2;

return -1;
}

另外,这会是 O(n log n) 时间复杂度吗?

最佳答案

static int maxNumber(int[] array) {
switch (array.length) {
case 1:
return array[0];
case 2:
return array[0] > array[1]
? array[0]
: array[1];
default:
int left = maxNumber(Arrays.copyOfRange(array, 0, (int) (array.length / 2)));
int right = maxNumber(Arrays.copyOfRange(array, (int) (array.length / 2), array.length));
return left > right
? left
: right;
}
}

如您所见,在递归中最重要的部分是处理结束条件。告诉递归何时停止。在我们的例子中,当数组中有一个或两个数字时我们就停止(如果我们将数组除以 3 个元素,我们会得到一个包含 2 的元素,一个包含 1 的元素)。

处理完结束条件后,剩下的就是递归了。您将数组分为两部分,并在每个部分上运行相同的函数。这将(最终)给你答案。

请记住,这种解决方案的空间复杂度相当高。每次调用递归函数时都会创建两个子数组。这可以通过以下方法签名来解决:maxNumber(array, start, end),它首先被称为 maxNumber(array, 0, array.length) 和每次递归运行时,您只需使用相同的数组引用调用该方法,而不是复制数组,但会缩小 startend 指针。

关于java - 分而治之算法数组中的最大数量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61313887/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com