现在我有一个“龙”的阵列。每个项目有两个值。一个身份证和一个号码。所以我的数组看起来像这样:
Dragon[] dragons = { new Dragon(2, 4),
new Dragon(83, 199),
new Dragon(492, 239),
new Dragon(2, 93),
new Dragon(24, 5)
};
如你所见,我有两条id为2的龙。我想完成的是,当发现一个复制品时,只需将复制品的数量加到第一个复制品的数量上,然后移除复制品。
我已经成功地做到了这一点,但是我会在数组的中间有一个空值,我不知道如何删除空值然后洗牌它们。
到目前为止,我已经做到了这一点,但它确实不能正常工作:
public static void dupeCheck(Dragon[] dragons) {
int end = dragons.length;
for (int i = 0; i < end; i++) {
for (int j = i + 1; j < end; j++) {
if (dragons[i] != null && dragons[j] != null) {
if (dragons[i].getId() == dragons[j].getId()) {
dragons[i] = new Item(dragons[i].getId(), dragons[i].getCount() + dragons[j].getCount());
dragons[j] = null;
end--;
j--;
}
}
}
}
}
3条答案
按热度按时间e0bqpujr1#
您可能被迫将结果存储在数组中,但这并不意味着您必须始终使用数组
一种解决方案是使用
Stream
api,将项目分组并添加计数,然后将结果再次保存到数组中。您可以获得如何使用Stream
api在此处求和。转换List<T>
变成一个T[]
这很简单,但无论如何,你这里有一个例子368yc8dk2#
您很可能不应该维护dragon类本身中每个龙的龙数。
除此之外,即使你被迫使用一个数组,你也应该创建一个交互Map来存储你的龙。
现在Map包含了龙的ID和龙之间的Map,以及正确的计数。要从这个Map创建一个数组,您可以
sshcrbum3#
数组的大小在创建后不能更改。
因此,您需要返回一个新数组或包含合并龙的列表。