方法过滤数组中的偶数值,并在新数组中返回它们



谁能告诉我如何更正以下代码才能正常工作?

编写一个方法 filterEvens,该方法接受整数数组并返回一个仅包含偶数值的新数组。

仅包含偶数值的新数组。例如:

int[] data = {1, 3, 4, 2, 0, 5, -2};
int[] evens = filterEvens(data);
public static int[] filterEvent(int[] data) {
    int countLength = 0;
    for (int i = 0; i < data.length; i++) {
        if (data[i] % 2 == 0) {
            countLength++; 
        }
    }
    int[] filArray = new int[countLength]; 
    for (int i = 0; i < data.length; i++) {
        if (data[i] % 2 == 0) {
            filArray[i] = data[i]; 
        }
    }
    return filArray;  
}

这里的问题是:

for (int i =0; i< data.length;i++)
  {
    if(data[i]%2==0)
    {
      filArray[i]= data[i] ; 
    }
}

您正在从值 0 --> data.length 循环。这是一个问题,因为数组 filArray[i] 的长度较小。

想象一下,你正在寻找某人的房子。在他们给你的街上,让我们说翡翠博士。门牌号可以是2000-3000。然后你被告知他们住在4000 Emerald Dr.这里的情况也是如此,只是电脑试图找到房子。

你填写了错误的索引。

你有

if(data[i]%2==0)
{
  filArray[i]= data[i] ; 
}

对于数据单元格是正确的,但 filArray 的单元格是错误的,将其更改为

 int j = 0; 
 for (int i =0; i< data.length;i++)
  {
    if(data[i]%2==0)
    {
      filArray[j]= data[i] ;
      j++; 
    }
  }

其余的看起来还可以。虽然你应该看看ArrayList因为它能够使它更有效率

最新更新