这是后续行动:在 Scala 中将一组字符串扩展为笛卡尔积
这个想法是你想要采取:
val sets = Set(Set("a","b","c"), Set("1","2"), Set("S","T"))
然后回来:
Set("a&1&S", "a&1&T", "a&2&S", ..., "c&2&T")
一个通用的解决方案是:
def combine[A](f:(A, A) => A)(xs:Iterable[Iterable[A]]) =
xs.reduceLeft { (x, y) => x.view.flatMap {a => y.map(f(a, _)) } }
使用如下:
val expanded = combine{(x:String, y:String) => x + "&" + y}(sets).toSet
从理论上讲,应该有一种方法来获取类型的输入Set[Set[A]]
并返回一个Set[B]
. 也就是说,在组合元素的同时转换类型。
一个示例用法是接收字符串集(如上)并输出它们连接的长度。中的f
函数combine
将采用以下形式:
(a:Int, b:String) => a + b.length
我无法提出实施方案。有人有答案吗?