java - 如何在数组递归方法中找到最小值?

标签 java recursion

public static int findMin(int[] numbers, int startIndex, int endIndex) {
    if (startIndex == endIndex){
        return numbers[startIndex];
    }
    else {
        int midIndex = (startIndex + endIndex) / 2;
        int leftMin = findMin(numbers, startIndex, midIndex);
        int rightMin = findMin(numbers, midIndex + 1, endIndex);
        if (leftMin < rightMin)
            return leftMin;
        else
            return rightMin;
    }
}

我真的很难理解这个 find min 递归。此递归方法查找数组中的最小数字。

我是这么理解的

假设我有一个数组 5, 3 , -5, 8,startIndex 为 0,endIndex 为 3

第一次,midIndex = (0+3)/2 =1。所以它除以 3 和 -5 之间。

然后转到 findMin,因此它将 Array, 0, 1 传回给 findMin。

然后,midIndex = (0+1)/2 = 0。并将 Array, 0, 0 传回给 findMin。

由于 startIndex 0 = endIndex 0,返回数字[startIndex](是 5?)。

我真的不明白这个方法是如何找到最小数字的。既然startIndex始终为0,为什么还需要返回numbers[startIndex]?

最佳答案

这是代码实现的总体思路:

要找到数组的最小元素,我们可以找到数组每一半的最小值,然后取这两个数字的最小值。

我们如何找到每一半的最小值?我们只是使用相同的技术将其分成四等分。

最终我们会问自己单个元素的最小元素是什么,当然就是那个元素。

图像中显示的算法实现了这个配方。

关于java - 如何在数组递归方法中找到最小值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43108383/

相关文章:

python - 如何使用递归获取节点邻居?

java - 如何在 GridView 中交换图像 (Android)

java - 打开doc文件时"The document is really a OOXML file"

java - 在java中使用全局变量递归

java - 为什么在使用递归时会收到此错误消息?

python - 在一个表达式中打印斐波那契数列的前 n 个数

java - 当编译 Scala 程序中导入的 Java 库时,Scala 编译器是否调用 javac?

java - Android:在适配器上显示dialogFrag会出现NullPointerException

java - 从 JPA 中的对象中选择列表

python - 递归在python代码中工作以找到最大值