合并不均匀长度列表与缺失匹配的默认值

时间:2017-06-03 11:51:00

标签: scala

我试图在Scala中配对两个列表,其中非匹配对应该被默认值替换,这是我到目前为止所做的但是你的所有都在某种程度上不足。

  

如何创建List((a,a),(b,empty),(c,c))???

case class Test(id: Option[Int] = None)
val empty = Test()
val a = Test(Some(1))
val b = Test(Some(2))
val c = Test(Some(3))

val cache = List(a,b,c)
val delta = List(a,c)

//Trial 1
val newCache1 = cache.zipAll(delta,empty,empty)

//Tial 2
val newCache2 = for {
  c <- cache
  d <- delta
  if c.id == d.id
} yield (c,d)

//Tial 3
val newCache3 = for {
  c <- cache
  d <- delta
} yield if (c.id == d.id) (c,d) else (c,empty)

1 个答案:

答案 0 :(得分:1)

将您的delta转换为地图,然后将它们连接起来。

  val deltaMap: Map[Int, Test] =
    delta.flatMap(x => x.id.map(id => id -> x)).toMap

  val newCache: Seq[(Test, Test)] = cache.map { c =>
    c -> c.id.flatMap(deltaMap.get).getOrElse(empty)
  }