Domanda

Sono nuovo a Scala e vuoi ottenere la cosa seguente fatta usando la mappa, la flatmap e / o per la comprensione.

Ho un elenco di elenchi l = List[List[T]].Ad esempio, l = [[1,2,3],[2,4,6,4],[3,4,6,2,3]].Si noti che ogni elenco all'interno di l può avere una lunghezza variabile.

Ora ho val x: List[Int] = [1,2,3] e voglio fare qualche operazione su x e l che restituisce [[1,1,2,3], [1,2,4,6,4], [1,3,4,6,2,3], [2,1,2,3], [2,2,4,6,4], [2,3,4,6,2,3], [3,1,2,3], [3,2,4,6,4], [3,3,4,6,2,3]] (l'ordine dei sublisti non importa).

Mi sento come se dovessi usare la mappa o flatmap o per-loop per farlo, ma dopo un lungo periodo di prova non riesco nemmeno a ottenere il tipo corretto.Qualcuno può aiutarmi su di esso?

È stato utile?

Soluzione

scala> val ls = List(List(1,2,3),List(2,4,6,4),List(3,4,6,2,3))
ls: List[List[Int]] = List(List(1, 2, 3), List(2, 4, 6, 4), List(3, 4, 6, 2, 3))

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

scala> for(x <- xs; l <- ls) yield x +: l
res22: List[List[Int]] = List(List(1, 1, 2, 3), List(1, 2, 4, 6, 4), List(1, 3, 4, 6, 2, 3), List(2, 1, 2, 3), List(2, 2, 4, 6, 4), List(2, 3, 4, 6, 2, 3), List(3, 1, 2, 3), List(3, 2, 4, 6, 4), List(3, 3, 4, 6, 2, 3))
.

Altri suggerimenti

x.flatMap(i => l.map(i::_))
.
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top