1

我试图弄清楚如何对一个数组中的输入列表进行排序,并从中制作两个不同的数组,无论是偶数还是奇数。我似乎无法将整数添加到 if 循环中的数组中。

这是我的代码:

 Scanner in = new Scanner (System.in);

System.out.print("Enter a number");
    int number = in.nextInt();


 int [] x = new int[0];
 int [] even = new int [0];
 int [] odd = new int [0];



for (int i = 0; i <x.length; i++)
{

    if (in.nextInt() == 0){
        for (i = 0; i <x.length; i++)
        {
            if (x[i] % 2 == 0)
            {
            even = even + x[i];
            System.out.print("Even numbers = " + even);
            i++;
            }
            if (x[i] % 2 != 0)
            {
            odd = odd + x[i];
            System.out.print("Odd numbers = " + odd);
            i++;
            }
        }
        break;
                }

    else {
        x[i] = number;
        i++;
        }

}
4

4 回答 4

2

Java中的数组是固定大小的。它们不会动态增长。ArrayList如果您想要一个可以增长和缩小的类似数组的容器,请使用。

List<Integer> even = new ArrayList<Integer>();
List<Integer> odd  = new ArrayList<Integer>();

if (...)
{
    even.add(number);
}
else
{
    odd.add(number);
}
于 2013-03-27T21:46:07.833 回答
2

您没有正确使用数组。我假设这是旨在教您如何使用它们的家庭作业。试试这个教程:

http://docs.oracle.com/javase/tutorial/java/nutsandbolts/arrays.html

祝你好运!

于 2013-03-27T21:47:28.607 回答
0

我不会使用三个数组来做到这一点。简单地遍历列表并有两个引用偶数和奇数索引的循环变量。像这样:

int evenIndex=0,oddIndex=1;
int evenSum=0,OddSum=0;
int [] x=new int[10];

 while(evenIndex <= x.length && oddIndex <= x.length)
        {
          evenSum+=x[evenIndex];
           oddSum+=x[oddIndex];


             evenIndex+=2;
             oddIndex+=2 

            }
于 2013-03-27T21:52:57.653 回答
0

两个很好的解决方案:

int [] x = new int[0];
LinkedList<Integer> even = new LinkedList<Integer>(),
                     odd = new LinkedList<Integer>();

for(int num: x)
    if (x & 1 == 1)
        odd.add(num);
    else
        even.add(num);

另一种选择是迭代,计算有多少偶数和奇数,分配正确大小的数组,然后将数字放入数组中。这也是一个 O(n) 解决方案。

于 2013-03-27T21:53:44.480 回答