【发布时间】:2017-03-30 04:07:20
【问题描述】:
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,返回numbers[startIndex](是5?)。
我真的不知道这个方法是如何找到最小数字的。既然startIndex总是为0,为什么还要返回numbers[startIndex]?
【问题讨论】: