我有一个数组,我想将它分成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
center
和right
。
我想问的是,是否有办法将两个ifs
合并为一个if
,非常优雅。
谢谢。
答案 0 :(得分: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);
答案 1 :(得分: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);