Как выбрать случайный элемент из массива в Scala?

например, существует массив Scala val A = Array("please", "help", "me"). Как выбрать случайный элемент из этого массива?

6 ответов


import java.util.Random
// ...
val rand = new Random(System.currentTimeMillis())
val random_index = rand.nextInt(A.length)
val result = A(random_index)

import scala.util.Random

val A = Array("please", "help", "me")
Random.shuffle(A.toList).head

import scala.util.Random

val A = List(1, 2, 3, 4, 5, 6)
A(Random.nextInt(A.size))

если вы хотите более идиоматическое решение, рассмотрите возможность использования шаблона typeclass (неявные классы в scala).

implicit class ListOps[A](list: List[A]) {
  def getRandomElement: Option[A] = list match {
    case Nil => None
    case _ => list.lift(scala.util.Random.nextInt(list.size))
  }
  def randomChoice(n: Int): Option[List[A]] =
    (1 to n).toList.foldLeft(Option(List[A]()))((acc, e) => getRandomElement.flatMap(r => acc.map(a => a :+ r)))
}

теперь, если неявный класс находится в области видимости, можно:

val randomElement: Option[String] = List("this", "is", "a", "list").getRandomElement

если вы уверены, что параметр содержит значение, вы можете использовать get метод.

randomElement.get // This will return a String (or a NotSuchElementExeption)

тем не менее, соответствие шаблону или getOrElse рекомендуется:

randomElement match {
  case None => ??? // This is what you do when a None is encounter (e.g. for empty lists)
  case Some(result) => ??? // The variable result contains a string. 

Примечание что randomChoice метод предполагает замену элементов.


лучшим ответом, который не включает в себя перетасовку массива вообще, было бы следующее:

import scala.util.Random

object sample {
  //gets random element from array
  def arr[T](items:Array[T]):T = {
    items(Random.nextInt(items.length))
  }
}

В общем


мы можем также добавить некоторую безопасность с Option монада (используя