当前位置: 首页 > 面试题库 >

如何使用Java8流对TreeSet列表进行排序

陆光济
2023-03-14
问题内容

我的清单包含[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和那种出来再做出新ListTreeSet的。但是,有某种班轮吗?

更新:

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比较,但还不知道如何使用它。