我希望添加一个整数元组列表,即给定一个arity元组的输入列表,产生一个arity元组k,其字段是列表中元组的相应字段的总和.
输入
List( (1,2,3),(2,3,-3),(1,1,1))
产量
(4,6,1)
解决方法
这可以使用
shapeless安全且非常简洁地完成,
scala> import shapeless._,Syntax.std.tuple._ import shapeless._ import Syntax.std.tuple._ scala> val l = List((1,-1),1)) l: List[(Int,Int,Int)] = List((1,1)) scala> l.map(_.toList).transpose.map(_.sum) res0: List[Int] = List(4,3)
请注意,与依赖强制转换的解决方案不同,此方法是类型安全的,并且在编译时而不是在运行时检测到任何类型错误,
scala> val l = List((1,"foo",Any,foo,1)) scala> l.map(_.toList).transpose.map(_.sum) <console>:15: error: Could not find implicit value for parameter num: Numeric[Any] l.map(_.toList).transpose.map(_.sum) ^