如何将列表元素放入 Java 中的字符串数组
How to put List elements to String Array in Java
有没有办法将列表元素放入 java 中的字符串数组?我使用自定义比较器按值对 Map 进行排序,现在尝试将键(字符串)元素放入数组中。我发现的唯一方法是同时遍历数组和排序列表并以这种方式填充数组,但它只将最后一个元素放入其中。
示例:
我的地图没有排序:{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();
}
那将 return 数组:c, a, b, d
作为补充建议,您还可以使用 Entry.comparingByValue()
方法创建 Comparator
。
Comparator<Entry<String,Integer>> valueComparator =
Entry.<String,Integer>comparingByValue().reversed();
它 returns 一个现成的 Comparator
按值的自然顺序进行比较。所以要反向排序,你只需要在 Comparator
接口中定义的 reversed()
方法上标记。
有没有办法将列表元素放入 java 中的字符串数组?我使用自定义比较器按值对 Map 进行排序,现在尝试将键(字符串)元素放入数组中。我发现的唯一方法是同时遍历数组和排序列表并以这种方式填充数组,但它只将最后一个元素放入其中。
示例:
我的地图没有排序:{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();
}
那将 return 数组:c, a, b, d
作为补充建议,您还可以使用 Entry.comparingByValue()
方法创建 Comparator
。
Comparator<Entry<String,Integer>> valueComparator =
Entry.<String,Integer>comparingByValue().reversed();
它 returns 一个现成的 Comparator
按值的自然顺序进行比较。所以要反向排序,你只需要在 Comparator
接口中定义的 reversed()
方法上标记。