¿Cuál es la mejor manera de encontrar una serie de ocurrencias de cada elemento de manera funcional / Scala?

Seq(Set("a", "b", "c"), Set("b"), Set("b", "c"))

Como resultado, necesito algo como

Set(("a", 1), ("b", 3), ("c", 2))

¡Gracias!

1
cyrillk 10 may. 2017 a las 19:22

2 respuestas

La mejor respuesta

Utilice { {X0}} y groupBy:

scala> val s = Seq(Set("a", "b", "c"), Set("b"), Set("b", "c"))
s: Seq[scala.collection.immutable.Set[String]] =
  List(Set(a, b, c), Set(b), Set(b, c))

scala> s.flatten
res0: Seq[String] =
  List(a, b, c, b, b, c)

scala> s.flatten.groupBy(identity)
res3: scala.collection.immutable.Map[String,Seq[String]] =
  Map(b -> List(b, b, b), a -> List(a), c -> List(c, c))

scala> s.flatten.groupBy(identity).map { case (k, v) => (k, v.size) }.toSet
res7: scala.collection.immutable.Set[(String, Int)] =
  Set((b,3), (a,1), (c,2))
2
OlivierBlanvillain 10 may. 2017 a las 16:29
scala> val x = Seq(Set("a", "b", "c"), Set("b"), Set("b", "c"))
x: Seq[scala.collection.immutable.Set[String]] = List(Set(a, b, c), Set(b), Set(b, c))
scala> (x.flatten groupBy identity mapValues (_.size)).toSet
res3: scala.collection.immutable.Set[(String, Int)] = Set((b,3), (a,1), (c,2))
-1
ryan 10 may. 2017 a las 19:58