Dans Scala, vous utilisez souvent un itérateur pour faire une for
boucle dans un ordre croissant comme:
for(i <- 1 to 10){ code }
Comment feriez-vous pour que ça passe de 10 à 1? Je suppose que 10 to 1
donne un itérateur vide (comme les mathématiques de plage habituelles)?
J'ai fait un script Scala qui le résout en appelant reverse sur l'itérateur, mais ce n'est pas sympa à mon avis, est-ce que la suite est la voie à suivre?
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
que vous pouvez utiliser à la place deto
pour exclure le point final de droite de la plage. Le point de terminaison de gauche est toujours inclus.Range.inclusive(10, 1, -1)
mérite d'être mentionnée.La réponse de @Randall est aussi bonne que l'or, mais par souci de finition, je voulais ajouter quelques variantes:
la source
by
et l'OMI ne doit en aucun cas être utiliséScala fournit de nombreuses façons de travailler en boucle vers le bas.
1ère solution: avec "vers" et "par"
2ème solution: avec "vers" et "inverser"
3ème solution: avec "à" uniquement
la source
Ayant programmé en Pascal, je trouve cette définition agréable à utiliser:
Utilisé de cette façon:
la source
Error:(57, 17) value class may not be a member of another class implicit class RichInt(val value: Int) extends AnyVal { ^
extends AnyVal
pièce (ce qui ne sert qu'à supprimer une surcharge).Vous pouvez utiliser la classe Range:
la source
Vous pouvez utiliser :
for (i <- 0 to 10 reverse) println(i)
la source
La boucle s'exécutera jusqu'à la valeur == 0, décrémentée à chaque fois de -1.
la source