[英]How to put List elements to String Array in Java
有没有办法在java中将列表元素放入字符串数组? 我使用自定义比较器按值对 Map 进行排序,现在尝试将 key(String) 元素放入数组中。 我发现的唯一方法是同时循环遍历数组和排序列表并以这种方式填充数组,但它只将最后一个元素放入其中。
示例:我的地图没有排序: {a=5, b=2, c=8, d=1}
使用自定义比较器排序后: [c=8, a=5, b=2, d=1]
现在我只需要将键值( c,a
等)放入元组final String[] lettersWithBigValues = new String[n]
其中n
是元组的长度。
然而,之后:
for (int i = 0; i < Integer.parseInt(args[1]); i++) { System.out.println(lettersWithBigValues[i]+","); }
控制台返回: d,d,d,d
假设控制台行参数为 4
这是完整的功能:
public String[] getTopLettersWithValues(final int n){
final String[] lettersWithBigValues = new String[n];
final Map<String, Integer> myMap = new HashMap<>();
int counter = 0;
for (final List<String> record : records) {
if (!myMap.containsKey(record.get(1))) {
myMap.put(record.get(1), counter += Integer.parseInt(record.get(4)));
} else {
myMap.computeIfPresent(record.get(1), (k,v) -> v + Integer.parseInt(record.get(4)));
}
}
System.out.println(myMap);
List<Map.Entry<String, Integer>> sorted = new LinkedList<>(myMap.entrySet());
// Sort list with list.sort(), using a custom Comparator
sorted.sort(valueComparator);
System.out.println(sorted);
for (int i = 0; i < lettersWithBigValues.length; i++) {
for (Map.Entry<String, Integer> values: sorted) {
lettersWithBigValues[i] = values.getKey();
}
}
return lettersWithBigValues;
}
其中记录是从 csv 文件读取的数据列表。
这是比较器:
public Comparator<Map.Entry<String, Integer>> valueComparator = (o1, o2) -> {
Integer v1 = o1.getValue();
Integer v2 = o2.getValue();
return v2.compareTo(v1);
};
您可以按如下方式获得键数组:
String [] lettersWithBigValues = myMap.entrySet().stream() // entries of your intial map
.sorted(valueComparator) // sorted by your comparator
.map(Map.Entry::getKey) // mapped to only the key e.g. 'd', 'a'
.toArray(String[]::new); // converted to array
在我看来,您错误地使用了嵌套 for 循环,您只需要一个:
for (int i = 0; i < lettersWithBigValues.length; i++) {
lettersWithBigValues[i] = sorted.get(i).getKey();
}
这将返回数组: c, a, b, d
作为附加建议,您还可以使用Entry.comparingByValue()
方法创建Comparator
器。
Comparator<Entry<String,Integer>> valueComparator =
Entry.<String,Integer>comparingByValue().reversed();
它返回一个现成的Comparator
,按值的自然顺序进行比较。 所以要反向排序,你只需要在Comparator
接口中定义的reversed()
方法上做标记。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.