使用 Java Lambda 创建两个(及更多)列表的笛卡尔积集合

Bri*_*ian 3 java lambda scala for-comprehension

我可以在 Scala 中使用以下方法轻松实现这一点:

def permute(xs: List[Int], ys: List[Int]) = {
  for {x <- xs; y <- ys} yield (x,y)
}
Run Code Online (Sandbox Code Playgroud)

所以如果我给它 {1, 2}, {3, 4} 我返回 {1, 3}, {1, 4}, {2, 3}, {2, 4}

我希望能够使用流将其转换为 java 8。

我遇到了一些困难,我希望能够将其扩展得更远,因为我希望能够从两个以上的列表中生成许多排列的测试样本。

即使使用流,它是否也不可避免地会成为嵌套的混乱,还是我不够应用自己?

在意识到我正在寻找笛卡尔积后发现了一些额外的答案:

如何使用 Java 8 流制作笛卡尔积?

Lou*_*man 7

我很难弄清楚您想要什么,看起来您正在尝试获得笛卡尔积?就像,给定{1, 2}{3, 4},你期待{(1, 3), (1, 4), (2, 3), (2, 4)}吗?(就其价值而言,我认为这与排列的数学定义没有任何关系,排列通常涉及对单个列表的内容进行排序的不同方式。)

可以这样写

xs.stream()
  .flatMap(x -> ys.stream().map(y -> Pair.of(x, y)))
  .collect(toList());
Run Code Online (Sandbox Code Playgroud)