gpt4 book ai didi

scala - 在 Scala 中添加整数元组列表

转载 作者:行者123 更新时间:2023-12-04 17:01:11 25 4
gpt4 key购买 nike

我希望添加一个整数元组列表,即给定一个元组 k 的输入列表,生成一个元组 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, 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)

请注意,与依赖强制转换的解决方案不同,这种方法是类型安全的,并且在编译时而不是运行时检测到任何类型错误,
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)
^

关于scala - 在 Scala 中添加整数元组列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18835723/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com