gpt4 book ai didi

java - 使用流交替混合两个列表

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:30:39 26 4
gpt4 key购买 nike

我使用循环实现了这个,但我不知道如何使用流来实现。我们得到两个列表,例如 1 2 3 和 4 5 6,混合后结果将是 1 4 2 5 3 6。

public <T> List<T> mixingList(List<T> list1, List<T> list2) {
List<T> result = new ArrayList<>();

int maxSize = list1.size() > list2.size() ? list1.size() : list2.size();

for (int i = 0; i < maxSize; i++) {
if (i < list1.size()) {
result.add(list1.get(i));
}

if (i < list2.size()) {
result.add(list2.get(i));
}
}

return result;
}

我为此准备测试。有3个测试first - 列表大小相同第二 - 有一个空列表第三 - 尺寸不同

@Test
public void shouldReturnShakedList() {
//given
List<Integer> list1 = new ArrayList<>(Arrays.asList(1, 3, 5));

List<Integer> list2 = new ArrayList<>(Arrays.asList(2, 4, 6));

//when
List<Integer> results = new ShakeListUtil().mixingList(list1, list2);

//then
Assertions.assertThat(results).containsExactly(1, 2, 3, 4, 5, 6);
Assertions.assertThat(results).hasSize(6);
}

@Test
public void shouldReturnJustList2IfList1IsEmpty() {
//given
List<Integer> list1 = new ArrayList<>();

List<Integer> list2 = new ArrayList<>(Arrays.asList(2, 4, 6));

//when
List<Integer> results = new ShakeListUtil().mixingList(list1, list2);

//then
Assertions.assertThat(results).containsExactly(2, 4, 6);
Assertions.assertThat(results).hasSize(3);

}

@Test
public void shouldReturnShakedListIfTheSizeListIsDifferent() {
//given
List<Integer> list1 = new ArrayList<>(Arrays.asList(1, 3));

List<Integer> list2 = new ArrayList<>(Arrays.asList(2, 4, 6));

//when
List<Integer> results = new ShakeListUtil().mixingList(list1, list2);

//then
Assertions.assertThat(results).containsExactly(1, 2, 3, 4, 6);
Assertions.assertThat(results).hasSize(5);
}

知道如何在 java 流上做到这一点吗?

最佳答案

这是一个使用流的解决方案:

public static <T> List<T> mixingList(List<T> list1, List<T> list2) {
int shorter = Math.min(list1.size(), list2.size());
int longer = Math.max(list1.size(), list2.size());
Stream<T> firstPart = IntStream.range(0, shorter).mapToObj(x -> Stream.of(list1.get(x), list2.get(x))).flatMap(x -> x);
if (longer > shorter) {
Stream<T> secondPart = (list1.size() > list2.size() ? list1 : list2).subList(shorter, longer).stream();
return Stream.concat(firstPart, secondPart).collect(Collectors.toList());
} else {
return firstPart.collect(Collectors.toList());
}
}

魔法发生在 mapToObjflatMap 中。它将每个索引映射到一个包含两个 列表元素的流,一个来自每个给定的列表。然后它使用 flatMap 将流的流展平。

之后,如果两个列表的大小不同,它会获取较长列表的其余部分并将其连接到末尾。

关于java - 使用流交替混合两个列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57007883/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com