我有一个存储键和值的树形图,如下所示:
key value
ko4 23
ko4 53
ko4 34
po1 100
po1 8
po1 90
po3 99
po3 234
po3 34
我想取每个键的平均值(并最终将它们打印到一个新文件中)。所以我会做平均值并将它们放在另一个地图中,HashMap 用于这个,因为我需要在将它们打印到新文件之前按值排序。新地图看起来像这样:
Key Value
ko4 36.6
po1 66
po3 122.3
我正试图让它发挥作用,但我很难过。也许我把事情复杂化了。这就是我所拥有的。
Map<String, Integer> map = new TreeMap<String, Integer>();
int sum = 0;
int average;
int number = 1;
map.put(key, value); //I actually read in a file to do this, but so it is reproducible I have it like this, people can put in whatever they please
String lastkey = map.key(0);//I don't know if I can get key somehow
for (int i = 0;i < map.size();i++){ //for the size of the map
thiskey = map.key(i);
if (thiskey.equals(lastkey)){ //if it is the same key as the last one
if (i == 0){
sum = map.get(i);
}else{
sum = sum + map.get(i); //add the values
number++;
}
average = sum / number;
}else{
lastkey = thiskey;
}
我需要一些帮助来弥补这里的一些差距。有一个更好的方法吗?