首页 > 编程语言 > 详细

java8 intstream流翻转顺序

时间:2021-01-20 23:28:45      阅读:136      评论:0      收藏:0      [点我收藏+]

参考资料:https://www.imooc.com/wenda/detail/590887


凤凰求蛊

这里的许多解决方案都对进行排序或反转IntStream,但这不必要地需要中间存储。Stuart Marks的解决方案是解决之道:

 

static IntStream revRange(int from, int to) {

    return IntStream.range(from, to).map(i -> to - i + from - 1);

}

它也可以正确处理溢出,并通过以下测试:

 

@Test

public void testRevRange() {

    assertArrayEquals(revRange(0, 5).toArray(), new int[]{4, 3, 2, 1, 0});

    assertArrayEquals(revRange(-5, 0).toArray(), new int[]{-1, -2, -3, -4, -5});

    assertArrayEquals(revRange(1, 4).toArray(), new int[]{3, 2, 1});

    assertArrayEquals(revRange(0, 0).toArray(), new int[0]);

    assertArrayEquals(revRange(0, -1).toArray(), new int[0]);

    assertArrayEquals(revRange(MIN_VALUE, MIN_VALUE).toArray(), new int[0]);

    assertArrayEquals(revRange(MAX_VALUE, MAX_VALUE).toArray(), new int[0]);

    assertArrayEquals(revRange(MIN_VALUE, MIN_VALUE + 1).toArray(), new int[]{MIN_VALUE});

    assertArrayEquals(revRange(MAX_VALUE - 1, MAX_VALUE).toArray(), new int[]{MAX_VALUE - 1});

}

java8 intstream流翻转顺序

原文:https://www.cnblogs.com/wulm/p/14304761.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!