Ответ 1
В документации :
a = [ "a", "a", "b", "b", "c" ]
a.uniq #gets you ["a", "b", "c"]
a.uniq.uniq! #gets you nil (no duplicates :)
Мне нужна коллекция, подобная набору. В основном я сканирую длинную строку и добавляю слова в коллекцию, но я хочу, чтобы можно было обнаружить, когда есть дубликаты.
Если набор недоступен, какой самый эффективный способ сделать это в Ruby? Брауни указывает, например, код.
В документации :
a = [ "a", "a", "b", "b", "c" ]
a.uniq #gets you ["a", "b", "c"]
a.uniq.uniq! #gets you nil (no duplicates :)
В рубине есть класс Set. Вы можете использовать его так:
require 'set'
set = Set.new
string = "a very very long string"
string.scan(/\w+/).each do |word|
unless set.add?( word )
# logic here for the duplicates
end
end
Хотя, мне интересно, хотите ли вы подсчитать экземпляры в этом случае, следующий пример будет лучше:
instances = Hash.new { |h, k| h[k] = 0 }
string.scan(/\w+/).each do |word|
instances[word] += 1
end
Проверьте этот URL /core/classes/Set.html на ruby-doc.org