我的清单包含[1,3,5][2,6,4]
大小等的集合。我尝试这样做,但似乎不起作用。
List<TreeSet<T>> block;
for(TreeSet<T> t : block){
block.stream().sorted((n,m)->n.compareTo(m)).collect(Collectors.toSet());
}
我想要的最终结果是[1,2,3][4,5,6]
。
我可以尝试添加在所有的元素ArrayList
和那种出来再做出新List
的TreeSet
的。但是,有某种班轮吗?
更新:
List<T> list=new ArrayList<T>();
for(TreeSet<T> t : block){
for(T t1 : t)
{
list.add(t1);
}
}
list=list.stream().sorted((n,m)->n.compareTo(m)).collect(Collectors.toList());
这可行,但是可以简化吗?
@Eugene的回答很甜蜜,因为番石榴很甜。但是,如果您碰巧在类路径中没有番石榴,这是另一种方式:
List<Set<Integer>> list = block.stream()
.flatMap(Set::stream)
.sorted()
.collect(partitioning(3));
首先,我将所有集合映射到一个流中,然后对所有元素进行排序,最后,将整个排序后的流收集到集合列表中。为此,我正在调用使用自定义收集器的辅助方法:
private static <T> Collector<T, ?, List<Set<T>>> partitioning(int size) {
class Acc {
int count = 0;
List<Set<T>> list = new ArrayList<>();
void add(T elem) {
int index = count++ / size;
if (index == list.size()) list.add(new LinkedHashSet<>());
list.get(index).add(elem);
}
Acc merge(Acc another) {
another.list.stream().flatMap(Set::stream).forEach(this::add);
return this;
}
}
return Collector.of(Acc::new, Acc::add, Acc::merge, acc -> acc.list);
}
该方法接收每个分区的大小,并使用Acc
本地类作为收集器要使用的可变结构。在Acc
类内部,我正在使用一个List
包含LinkedHashSet
实例的实例,该实例将保存流的元素。
将Acc
类保存所有已已收集到的元素的个数。在该add
方法中,我计算列表的索引并递增此计数,如果列表的该位置没有设置,则将新的空值附加LinkedHashSet
到该位置。然后,将元素添加到集合中。
在调用sorted()
流对元素进行收集之前对其进行排序时,我需要使用保留插入顺序的数据结构。这就是为什么我要使用ArrayList
外部列表和LinkedHashSet
内部集合。
该merge
方法将由并行流使用,以合并两个先前累积的Acc
实例。我只是通过委托给方法,将接收到的Acc
实例的所有元素添加到该Acc
实例中add
。
最后,我正在使用Collector.of
基于Acc
类方法的收集器。最后一个参数是装订器功能,它仅返回Acc
实例的列表。
我正在使用java lambda对列表进行排序。 我怎样才能反向排序呢?
我有一个这样的方法: 此方法需要以如下字符串形式返回3个最昂贵项目的产品ID:“item1,item2,item3”。我应该只能使用溪流,我被困在这里了。我应该能够按值对项目进行排序,然后获得产品ID,但我似乎无法使其正常工作。 编辑: 产品ID位于入口类中
假设我有一个walls列表listOfWalls,并且每个wall对象具有以下层次结构: 所以为了在这个列表中获得一些墙的wallMaterialType,我会这样做 null 从那里我不知道该怎么走?感谢帮助。
本文向大家介绍如何使用JavaScript对HTML列表进行排序?,包括了如何使用JavaScript对HTML列表进行排序?的使用技巧和注意事项,需要的朋友参考一下 要使用JavaScript对HTML列表进行排序,代码如下- 示例 输出结果 上面的代码将产生以下输出- 在点击“点击排序”按钮-
我有这个列表,我想按保留顺序订购,但我没有在自动完成辅助中找到任何函数 我也尝试过: 但是我有编译错误:
我有以下课程 我正在尝试按贡献者名称和角色名称对ResourceContributor列表进行排序。到目前为止,我得到的是: 我已经尝试使用then比较,但还不知道如何使用它。