在Scala中添加整数元组列表

我希望添加一个整数元组列表,即给定一个arity元组的输入列表,产生一个arity元组k,其字段是列表中元组的相应字段的总和.

输入

List( (1,2,3),(2,3,-3),(1,1,1))

产量

(4,6,1)

我试图使用foldLeft,但我无法编译它.现在,我正在使用for循环,但我正在寻找一个更简洁的解决方案.

解决方法

这可以使用 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)
                                          ^

相关文章

共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 Tw...
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即...
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相...
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相...
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日...