Генератор быстрой перестановки - PullRequest
7 голосов
/ 04 января 2011

Я написал генератор перестановок для списков Scala, который генерирует все перестановки данного списка.До сих пор у меня есть следующее, основанное на этой реализации на Haskell (и я думаю, что это более эффективно, чем некоторые другие варианты, которые я пробовал).Есть ли способы сделать это еще более эффективным, или я охватил все свои базы?

   /** For each element x in List xss, returns (x, xss - x) */
   def selections[A](xss:List[A]):List[(A,List[A])] = xss match {
      case Nil => Nil
      case x :: xs =>
         (x, xs) :: (for( (y, ys) <- selections (xs) )
            yield (y, x :: ys))
   }

   /** Returns a list containing all permutations of the input list */
   def permute[A](xs:List[A]):List[List[A]] = xs match {
      case Nil => List(Nil)

      //special case lists of length 1 and 2 for better performance
      case t :: Nil => List(xs)
      case t :: u :: Nil => List(xs,List(u,t))

      case _ => 
         for ( (y,ys) <- selections(xs); ps <- permute(ys))
            yield y :: ps
   }

1 Ответ

3 голосов
/ 05 января 2011

В Scala 2.9 extempore добавили несколько полезных методов в класс коллекции scala, в том числе Seq.permutations, которые генерируют все перестановки этого seq. См. текст ссылки . И у меня есть нерекурсивная реализация, которая, я думаю, будет иметь лучшую производительность. См. Нерекурсивная реализация SeqLike.permutations

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...