Existe-t-il un moyen rapide d'obtenir une permutation (aléatoire) d'un hachage donné ? Par exemple, avec les tableaux, je peux utiliser la fonction échantillon comme dans
ruby-1.9.2-p180 :031 > a = (1..5).to_a
=> [1, 2, 3, 4, 5]
ruby-1.9.2-p180 :032 > a.sample(a.length)
=> [3, 5, 1, 2, 4]
Pour les hachages, je peux utiliser la même méthode sur les clés de hachage et construire un nouveau hachage avec
ruby-1.9.2-p180 :036 > h = { 1 => 'a', 2 => 'b', 3 => 'c' }
=> {1=>"a", 2=>"b", 3=>"c"}
ruby-1.9.2-p180 :037 > h.keys.sample(h.length).inject({}) { |h2, k| h2[k] = h[k]; h2 }
=> {3=>"c", 2=>"b", 1=>"a"}
mais c'est tellement laid. Existe-t-il une méthode "type" pour les hachages qui permet d'éviter tout ce code ?
Mise à jour Comme l'a souligné @Michael Kohl dans les commentaires, cette question n'a de sens que pour ruby 1.9.x. Puisque dans la version 1.8.x les hachures ne sont pas ordonnées, il n'y a aucun moyen de le faire.