java8 intstream流翻轉順序


 

鳳凰求蠱

這里的許多解決方案都對進行排序或反轉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});

}

 

 

 

參考資料:https://www.imooc.com/wenda/detail/590887


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM