我遇到了以下问题:创建一个递归方法来检查给定数组是否包含给定值。这应该通过将数组分成两半来完成,因此需要两次递归调用。
我的问题是方法头不包含任何指定的索引范围,可以通过递归进行更改,以便搜索数组中的每个值。我现在尝试将与值进行比较的索引修复为 0 并继续将数组分成两半,以便数组中的每个值在某个时刻都有索引 0。然而,它不起作用,我不明白为什么。如果有人能给我一个关于我做错了什么的线索,那会很有帮助,因为我对 Java 还是很陌生。
我的限制如下:没有改变方法头,没有全局变量,没有循环,只允许的类是:String、Array、Math、Integer。
例子:int[] array = {2, 4, 7, 10, -10, 4, 0, 0, 27, 11, 4, 6};
System.out.println(containsValue(array4, 11));
这应该是真的,在我的代码中它是假的。
代码:
private static boolean containsValue(int[] workArray, int value) {
int count = 0;
boolean hasValue;
if (workArray.length > 1) {
int[] firstHalfArray = Arrays.copyOfRange(workArray, 0, (workArray.length / 2) - 1);
if (firstHalfArray[count] == value) {
hasValue = true;
return containsValue(firstHalfArray, value) || hasValue;
}
}
if (workArray.length > 1) {
int[] secondHalfArray = Arrays.copyOfRange(workArray, 6, workArray.length - 1);
if (secondHalfArray[count] == value) {
hasValue = true;
return containsValue(secondHalfArray, value) || hasValue;
}
}
return false;
}
public static void main(String[] args) {
int[] array4 = {2, 4, 7, 10, -10, 4, 0, 0, 27, 11, 4, 6};
System.out.println(containsValue(array4, 11));
System.out.println(containsValue(array4, 2));
System.out.println(containsValue(array4, 25));
System.out.println(containsValue(array4, 0));
System.out.println(containsValue(array4, 14));
System.out.println(containsValue(array4, 6));
}
提前致谢
更新:我已经调整并调整了我的代码。我的基本情况大错特错,谢谢。它的其余部分仍然没有按照我想要的方式工作,即使我的递归被正确实现(我仍然继续将它分成两半,直到达到基本情况(workArray.lenght == 1)并检查是否数组中的单个 int 等于 value。我还做错了什么?
private static boolean containsValue(int[] workArray, int value) {
int count = 0;
if (workArray.length > 1) {
int[] firstHalfArray = Arrays.copyOfRange(workArray, 0, (workArray.length / 2));
return containsValue(firstHalfArray, value);
}
if (workArray.length > 1) {
int[] secondHalfArray = Arrays.copyOfRange(workArray, workArray/2, workArray.length - 1);
return containsValue(secondHalfArray, value);
}
if (workArray[count] == value) {
return true;
}
return false;
最佳答案
我不明白
private static boolean containsValue(int[] workArray, int value) {
if (workArray.length == 0) return false;
if (workArray[0] == value) return true;
if (workArray.length == 1) return false;
int middle = workArray.length / 2;
int[] firstHalfArray = Arrays.copyOfRange(workArray, 0, middle);
if(containsValue(firstHalfArray, value)) return true;
int[] secondHalfArray = Arrays.copyOfRange(workArray, middle, workArray.length);
return containsValue(secondHalfArray, value);
}
关于java - 检查数组是否包含具有递归和某些限制的 int,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59021441/