Вопрос

Мне нужна коллекция, похожая на набор.По сути, я сканирую длинную строку и добавляю слова в коллекцию, но я хочу иметь возможность определять, когда есть дубликаты.

Если наборы недоступны, каков наиболее эффективный способ сделать это в Ruby?Брауни указывает пример кода.

Это было полезно?

Решение

Из самого Документация:

a = [ "a", "a", "b", "b", "c" ]
a.uniq  #gets you   ["a", "b", "c"]
a.uniq.uniq! #gets you nil (no duplicates :)

Другие советы

В ruby есть класс 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

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top