加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Java 8使用特定范围排序

发布时间:2020-12-15 08:27:29 所属栏目:Java 来源:网络整理
导读:我有一个具有totalDistance属性的Distance对象. 使用 java 8 steams我需要通过totalDistance对List进行排序. 我知道我可以使用以下内容对此列表进行排序: .sorted(Comparator.comparing(Distance::totalDistance).reversed()) 我的问题是我需要按特定范围对
我有一个具有totalDistance属性的Distance对象.
使用 java 8 steams我需要通过totalDistance对List进行排序.

我知道我可以使用以下内容对此列表进行排序:

.sorted(Comparator.comparing(Distance::totalDistance).reversed())

我的问题是我需要按特定范围对其进行排序.

例如,对获得前50个的距离进行排序,然后从50到100进行排序,依此类推……但是通过这些间隔不应该对它进行排序.

例如,使用以下列表:

List<Distance> list = new ArrayList<>();
list.add(new Distance(100));
list.add(new Distance(10));
list.add(new Distance(1));
list.add(new Distance(40));
list.add(new Distance(30));

按范围排序我会得到:

10,1,40,30,100

有关如何使用java 8实现这种排序范围间隔的任何想法?

解决方法

我相当肯定你可以在比较它们时将值除以你的范围长度(在这种情况下是50):

List<Distance> list = Arrays.asList(new Distance(130),new Distance(100),new Distance(10),new Distance(1),new Distance(40),new Distance(30),new Distance(120)
    );

list.sort(Comparator.comparingInt(d -> d.getTotalDistance() / 50));

list.stream().mapToInt(Distance::getTotalDistance).forEach(System.out::println); // assuming the getter for 'totalDistance'

输出:

06001

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读