我希望在Scala中有一个可遍历的二元算子cross
(叉积/笛卡尔积):
val x = Seq(1, 2)
val y = List('hello', 'world', 'bye')
val z = x cross y # i can chain as many traversables e.g. x cross y cross w etc
assert z == ((1, 'hello'), (1, 'world'), (1, 'bye'), (2, 'hello'), (2, 'world'), (2, 'bye'))
在Scala中,仅使用Scala本身(而不是像scalaz这样的库)实现此操作的最佳方法是什么?