5

整数のタプルのリストを追加します。つまり、アリティ k のタプルの入力リストが与えられた場合、アリティkタプルを生成します。そのフィールドは、リスト内のタプルの対応するフィールドの合計です。

入力

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

出力

(4, 6, 1)

を使用しようとしましたがfoldLeft、コンパイルできません。現在、forループを使用していますが、より簡潔な解決策を探していました。

4

3 に答える 3

7

これは、 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)
                                          ^
于 2013-09-16T21:28:36.557 に答える
3
scala> val tuples = List( (1,2,3), (2,3,-3), (1,1,1))
tuples: List[(Int, Int, Int)] = List((1,2,3), (2,3,-3), (1,1,1))

scala> tuples.map(t => t.productIterator.toList.map(_.asInstanceOf[Int])).transpose.map(_.sum)
res0: List[Int] = List(4, 6, 1)

productIteratorを呼び出すと型情報が失われるTuple3ため、 からAnyに戻す必要がありIntます。

タプルに常に同じ型が含まれる場合は、 などの別のコレクションを使用することをお勧めしListます。はTuple、異種のタイプに適しています。productIterator同じ型があり、ソリューションを使用して型情報を失わない場合は、よりエレガントです。

scala> val tuples = List(List(1,2,3), List(2,3,-3), List(1,1,1))
tuples: List[List[Int]] = List(List(1, 2, 3), List(2, 3, -3), List(1, 1, 1))

scala> tuples.transpose.map(_.sum)
res1: List[Int] = List(4, 6, 1)
于 2013-09-16T19:39:24.887 に答える
2
scala> val list = List( (1,2,3), (2,3,-3), (1,1,1))
list: List[(Int, Int, Int)] = List((1,2,3), (2,3,-3), (1,1,1))

scala> list.foldRight( (0, 0, 0) ){ case ((a, b, c), (a1, b1, c1)) => (a + a1, b + b1, c + c1) }
res0: (Int, Int, Int) = (4,6,1)
于 2013-09-16T19:33:06.023 に答える