我希望添加一个整数元组列表,即给定arity元组的输入列表k,生成一个arity元组k,其字段是列表中元组的相应字段的总和.
List( (1,2,3), (2,3,-3), (1,1,1))
Run Code Online (Sandbox Code Playgroud)
(4, 6, 1)
Run Code Online (Sandbox Code Playgroud)
我试图使用foldLeft,但我无法编译.现在,我正在使用for循环,但我正在寻找一个更简洁的解决方案.
这可以安全,非常简洁使用进行类型不成形,
scala> import shapeless._, syntax.std.tuple._
import shapeless._
import syntax.std.tuple._
scala> val l = List((1, 2, 3), (2, 3, -1), (1, 1, 1))
l: List[(Int, Int, Int)] = List((1,2,3), (2,3,-1), (1,1,1))
scala> l.map(_.toList).transpose.map(_.sum)
res0: List[Int] = List(4, 6, 3)
Run Code Online (Sandbox Code Playgroud)
请注意,与依赖强制转换的解决方案不同,此方法是类型安全的,并且在编译时而不是在运行时检测到任何类型错误,
scala> val l = List((1, 2, 3), (2, "foo", -1), (1, 1, 1))
l: List[(Int, Any, Int)] = List((1,2,3), (2,foo,-1), (1,1,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)
^
Run Code Online (Sandbox Code Playgroud)