Я хочу иметь двоичный оператор cross
(кросс-произведение/декартово произведение), который работает с обходами в Scala:
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 (т.е. не использовать что-то вроде scalaz)?