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))
                
untilpuede usar en lugar detopara 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
byy 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 AnyValparte (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