68 votes

Comment puis-je vérifier un tableau pour les doublons?

J'ai un tableau A. je voudrais vérifier si elle contient des valeurs en double. Comment pourrais-je le faire?

127voto

sepp2k Points 157757

Appelez simplement uniq "(qu'il renvoie un nouveau tableau sans les doublons) et voir si l' uniqed matrice a moins d'éléments que l'original:

if a.uniq.length == a.length
  puts "a does not contain duplicates"
else
  puts "a does contain duplicates"
end

Notez que les objets dans le tableau doivent répondre à des hash et eql? dans un sens pour uniq pour fonctionner correctement.

36voto

jmonteiro Points 773

Afin de trouver le double des éléments, j'utilise cette méthode (avec Ruby 1.9.3):

array = [1, 2, 1, 3, 5, 4, 5, 5]
=> [1, 2, 1, 3, 5, 4, 5, 5]
dup = array.select{|element| array.count(element) > 1 }
=> [1, 1, 5, 5, 5]
dup.uniq
=> [1, 5]

10voto

pinouchon Points 7706

Si vous voulez retourner les doublons, vous pouvez faire ceci:

dups = [1,1,1,2,2,3].group_by{|e| e}.keep_if{|_, e| e.length > 1}
# => {1=>[1, 1, 1], 2=>[2, 2]}

Si vous voulez juste les valeurs:

dups.keys
# => [1, 2]

Si vous souhaitez que le nombre de doublons:

dups.map{|k, v| {k => v.length}}
# => [{1=>3}, {2=>2}]

4voto

fakeleft Points 903

Pourriez monkeypatch Tableau si vous utilisez plus d'une fois:

class Array
  def uniq?
    self.length == self.uniq.length
  end
end

Alors:

irb(main):018:0> [1,2].uniq?
=> true
irb(main):019:0> [2,2].uniq?
=> false

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X