java - 检查数组是否包含具有递归和某些限制的 int

标签 java arrays recursion

我遇到了以下问题:创建一个递归方法来检查给定数组是否包含给定值。这应该通过将数组分成两半来完成,因此需要两次递归调用。

我的问题是方法头不包含任何指定的索引范围,可以通过递归进行更改,以便搜索数组中的每个值。我现在尝试将与值进行比较的索引修复为 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;

最佳答案

我不明白

  • 为什么你在这里需要这个递归
  • 为什么要复制数组子集...最好在方法参数 containsValue(int[] workArray, int value, int startindex, int endidex) 中保留搜索范围
  • copyOfRange 中的最后一个属性是结束索引,但仅是
    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/

    相关文章:

    c - union 结构在将其分配给字节数组后获得意外数据

    Python递归向后打印列表中的项目

    java - 为什么我的if没有执行

    python - 如何在Python中找到包含数字和字符串的列表中的最大数字?

    c - 在 C 文件中写入和打印数组中的字符串

    javascript - 中断递归函数

    php - PHP这里如何避免无限递归?

    java - ImageView 中的旋转图像

    java - Iterator 类型不是通用的;它不能使用参数 <CustomTypeName> 进行参数化

    java - 通过 Azure Java SDK 向服务总线主题发送消息时出现 500 内部服务器错误