In Scala verwenden Sie häufig einen Iterator, um eine for
Schleife in aufsteigender Reihenfolge auszuführen, z.
for(i <- 1 to 10){ code }
Wie würden Sie es tun, damit es von 10 auf 1 geht? Ich denke, 10 to 1
gibt einen leeren Iterator (wie übliche Bereichsmathematik)?
Ich habe ein Scala-Skript erstellt, das es löst, indem ich den Iterator umgekehrt aufrufe, aber meiner Meinung nach ist es nicht schön. Ist das Folgende der richtige Weg?
def nBeers(n:Int) = n match {
case 0 => ("No more bottles of beer on the wall, no more bottles of beer." +
"\nGo to the store and buy some more, " +
"99 bottles of beer on the wall.\n")
case _ => (n + " bottles of beer on the wall, " + n +
" bottles of beer.\n" +
"Take one down and pass it around, " +
(if((n-1)==0)
"no more"
else
(n-1)) +
" bottles of beer on the wall.\n")
}
for(b <- (0 to 99).reverse)
println(nBeers(b))
until
dass Sie anstelle von auchto
den rechten Endpunkt aus dem Bereich ausschließen können. Der linke Endpunkt ist immer enthalten.Range.inclusive(10, 1, -1)
verdient Erwähnung.Die Antwort von @Randall ist gut wie Gold, aber der Vollständigkeit halber wollte ich ein paar Variationen hinzufügen:
quelle
by
und IMO sollte unter keinen Umständen verwendet werdenScala bietet viele Möglichkeiten, um in einer Schleife nach unten zu arbeiten.
1. Lösung: mit "to" und "by"
2. Lösung: Mit "to" und "reverse"
3. Lösung: nur mit "bis"
quelle
Nachdem ich in Pascal programmiert habe, finde ich diese Definition gut zu verwenden:
So verwendet:
quelle
Error:(57, 17) value class may not be a member of another class implicit class RichInt(val value: Int) extends AnyVal { ^
extends AnyVal
Teil (das nur dazu dient, etwas Overhead zu entfernen).Sie können die Range-Klasse verwenden:
quelle
Sie können verwenden:
for (i <- 0 to 10 reverse) println(i)
quelle
Die Schleife wird bis zum Wert == 0 ausgeführt, der jedes Mal um -1 dekrementiert wird.
quelle