0

我有一个数组,我想将它几乎平均分成 3 个部分。我知道该怎么做,但我也想处理数组中有 2 个元素的情况。

在这种情况下,我希望该center数组是一个零元素 ( center.length == 0) 的空数组(必须有零元素,而不仅仅是一个空数组)。

这是我所做的:

int elements = data.length;
int sizeLeft;
int sizeCenter;
int sizeRight;
    if (elements > 2) {
        if (elements % 3 == 0) {
            sizeLeft = elements / 3;
            sizeCenter = elements / 3;
            sizeRight = elements / 3;
        } else if (elements % 3 == 1) {
            sizeLeft = (elements / 3) + 1;
            sizeCenter = elements / 3;
            sizeRight = elements / 3;
        } else { //if (elements % 3 == 2)
            sizeLeft = (elements / 3) + 1;
            sizeCenter = elements / 3;
            sizeRight = (elements / 3) + 1;
        }

        int[] left = makeArray(data, 0, sizeLeft);
        int[] center = makeArray(data, sizeLeft, sizeCenter);
        int[] right = makeArray(data, sizeLeft + sizeCenter, sizeRight);

    } else if (elements == 2) {
        int[] center = new int[]{};
        int[] left = makeArray(data, 0, 1);
        int[] right = makeArray(data, 1, 1);
    }

makeArray方法:

public static int[] makeArray(int[] data, int startCopy, int size) {
    int[] array = new int[size];
    System.arraycopy(data, startCopy, array, 0, size);
    return array;
}

data是将要分成 3 部分的主数组:left centerright.

我想问的是,是否有办法将两者完美地结合ifs在一起。if

谢谢你。

4

2 回答 2

1

你可以简单地写:

int elements = data.length;
int mod = elements % 3;
int div = elements / 3;

int sizeLeft = div + (mod > 0 ? 1 : 0);
int sizeCenter = div;
int sizeRight = div + (mod > 1 ? 1 : 0);
于 2012-05-22T13:02:37.077 回答
0

试试这个

        int len= data.Length;
        int pos = len / 3;
        int remaining = len % 3;

        int firstpos = pos + (remaining > 0 ? 1 : 0);
        int centerpos=pos;
        int lastpos = pos + (remaining / 2);
于 2012-05-22T13:18:39.427 回答