1

我正在使用以下方法对数组执行线性搜索:

private int[] theArray = new int[50]; 
private int arraySize = 10; 

public String linearSearchForValue(int value){

    boolean valueInArray = false;
    String indexsWithValue = "";

    for(int i = 0; i < arraySize; i++) {
        if(theArray[i] == value) {
            valueInArray = true;
            indexsWithValue+= i + " ";
        }
        printHorzArray(i, -1);
    }

    if(!valueInArray){
        indexsWithValue = "None";
    }

    System.out.print("The Value was Found in the Following: " + indexsWithValue);
    System.out.println();
    return indexsWithValue;
}

// Print Array
public void printHorzArray(int i, int j) {

for(int n = 0; n < 51; n++) {
    System.out.print("-");
}

System.out.println();

for(int n = 0; n < arraySize; n++) {
    System.out.print("| " + n + "  ");
}

System.out.println("|");

for(int n = 0; n < 51; n++) {
    System.out.print("-");
}

System.out.println();

for(int n = 0; n < arraySize; n++) {
System.out.print("| " + theArray[n] + " ");

}

在 linearSearchForValue 方法中,设置 indexsWithValue为空字符串的目的是什么。然后在 if 语句 indexsWithValue+= i + " ";中将空字符串添加到i + " ". 我不明白做这两件事的目的。

注意:数组元素是随机生成的。

输出:在此处输入图像描述

4

2 回答 2

1

你不需要它。它只是为了输出。

indexsWithValue+= i + " ";

确保连接所有匹配的索引。

你的输出会像。

i1 i2 i3 ....

其中 i1,i2,... 是找到的匹配项。

于 2016-10-19T06:05:49.827 回答
1

你不需要它。在您的代码中,当您在数组中没有提供的键时,您会得到“无”。

因此,您默认将其声明为字符串。

于 2016-10-19T06:10:29.123 回答