En Scala, a menudo usa un iterador para hacer un for
bucle en un orden creciente como:
for(i <- 1 to 10){ code }
¿Cómo lo harías para que pase de 10 a 1? supongo10 to 1
da un iterador vacío (como las matemáticas de rango habituales).
Hice un script de Scala que lo resuelve llamando a reverse en el iterador, pero en mi opinión no es agradable, ¿es el siguiente el camino a seguir?
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
puede usar en lugar deto
para excluir el punto final de la derecha del rango. Siempre se incluye el punto final de la izquierda.Range.inclusive(10, 1, -1)
merece una mención.La respuesta de @Randall es tan buena como el oro, pero en aras de la finalización, quería agregar un par de variaciones:
fuente
by
y IMO no debe usarse bajo ninguna circunstanciaScala proporciona muchas formas de trabajar hacia abajo en bucle.
Primera solución: con "to" y "by"
Segunda solución: con "to" y "reverse"
Tercera solución: solo con "a"
fuente
Habiendo programado en Pascal, encuentro esta definición agradable de usar:
Usado de esta manera:
fuente
Error:(57, 17) value class may not be a member of another class implicit class RichInt(val value: Int) extends AnyVal { ^
extends AnyVal
parte (que solo sirve para eliminar algunos gastos generales).Puede usar la clase Range:
fuente
Puedes usar :
for (i <- 0 to 10 reverse) println(i)
fuente
El ciclo se ejecutará hasta el valor == 0, decrementado cada vez en -1.
fuente