如何解决有没有办法创建一个具有 ArrayList 动态功能的 int[]? 颗粒的尺寸分布
所以我试图实现一种方法,该方法返回一个包含粒子大小分布的数组(其中粒子的大小是像素的数量)。我尝试过的是使用和 int[] 并将其设置为不同的长度以尝试匹配粒子的最大/最小尺寸。我很快得出结论,这不是可行的方法,因为尺寸差异很大。我基本上需要的是一个大小动态的 int[]。
到目前为止我尝试过的:
地图有每个粒子的标签(整数)(像素列表)
private int[] particleSizeDistribution(Map<Integer,List<Pixel>> particleMap) {
int[] particleSizeDistribution = new int[tried many different lengths here :)];
for(Map.Entry<Integer,List<Pixel>> entry : particleMap.entrySet()) {
particleSizeDistribution[entry.getValue().size()] += 1;
}
return particleSizeDistribution;
}
粒子是从显微镜的一系列图像中生成的。使用 int[] 的问题是我需要选择一个固定长度。一项实验可能会显示 20-200 像素和接下来的 100-1500 像素范围内的粒子。
我知道 ArrayLists 是动态的,我尝试使用它但是如果第一个粒子的大小为 125 像素(意味着在索引 125 处为 +1)并且列表为空怎么办?我尝试时没有用。
希望有人能帮我找到正确的方向!
周末愉快:)
解决方法
正如评论中所建议的,最好使用 Map<Integer,Integer>
+ List<Pixel>
将现有地图重新映射到 Collectors.groupingBy
中,其中键的大小为 Collectors.summingInt
:
SortedMap<Integer,Integer> particleSizeMap = particleMap.entrySet().stream()
.collect(Collectors.groupingBy(
e -> e.getValue().size(),TreeMap::new,// sort by the particle list size
Collectors.summingInt(e -> 1)
));
那么排序后的映射可以用来构建一个数组:
int[] particleSizeDistribution = IntStream.rangeClosed(0,particleSizeMap.lastKey())
.map(i -> particleSizeMap.getOrDefault(i,0))
.toArray();