谁能告诉我如何更正以下代码才能正常工作?
编写一个方法 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
因为它能够使它更有效率