Improve `insertInStream`

New version works with infinite streams and has constant space/time complexity.
This commit is contained in:
Geoffrey Churchill 2022-07-31 14:25:22 -04:00 committed by GitHub
parent 8db0d7b277
commit 5a1208f029
1 changed files with 14 additions and 0 deletions

View File

@ -2,9 +2,13 @@ package com.baeldung.streams;
import org.junit.Test;
import java.util.Iterator;
import java.util.List;
import java.util.Spliterator;
import java.util.Spliterators;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import java.util.stream.StreamSupport;
import static org.junit.Assert.assertEquals;
@ -40,6 +44,16 @@ public class StreamAddUnitTest {
assertEquals(resultList.get(3), (Double) 9.9);
}
private static <T> Stream<T> insertInStream(Stream<T> stream, T elem, int index) {
final Spliterator<T> spliterator = stream.spliterator();
final Iterator<T> iterator = Spliterators.iterator(spliterator);
return Stream.concat(Stream.concat(
Stream.generate(iterator::next).limit(index),
Stream.of(elem)),
StreamSupport.stream(spliterator, /* parallel= */ false));
}
private <T> Stream<T> insertInStream(Stream<T> stream, T elem, int index) {
List<T> result = stream.collect(Collectors.toList());
result.add(index, elem);