Самый быстрый способ найти строку в массив строк

17

Сценарий должен проверить, присутствует ли один предопределенный IP-адрес в большом массиве IP-адресов. В настоящее время я кодирую эту функцию следующим образом (говоря, что «ips» - это мой массив IP, а «ip» - предопределенный ip)

ips.each do |existsip|
  if ip == existsip
    puts "ip exists"
    return 1
  end
end
puts "ip doesn't exist"
return nil

Есть ли более быстрый способ сделать то же самое?

Правка: Я, возможно, неправильно выразился. Я могу сделать array.include? но я хотел бы знать: Is array.include? метод, который даст мне самый быстрый результат?

    
задан Cocotton 16.02.2012 в 16:25
источник

5 ответов

30

Вы можете использовать Установить . Он реализован поверх Hash и будет быстрее для больших наборов данных - O (1).

require 'set'
s = Set.new ['1.1.1.1', '1.2.3.4']
# => #<Set: {"1.1.1.1", "1.2.3.4"}> 
s.include? '1.1.1.1'
# => true 
    
ответ дан Alex Kliuchnikau 16.02.2012 в 16:29
источник
4

Вы можете использовать метод include Array #, чтобы вернуть true / false.

Ссылка

if ips.include?(ip) #=> true
  puts 'ip exists'
else
  puts 'ip  doesn\'t exist'
end
    
ответ дан ericraio 16.02.2012 в 16:34
источник
3

Более быстрый способ:

if ips.include?(ip)
  puts "ip exists"
  return 1
else
  puts "ip doesn't exist"
  return nil
end
    
ответ дан Don Cruickshank 16.02.2012 в 16:29
источник
2

Вы пытались включить Array # include? функция?

Ссылка

Из источника вы можете видеть почти то же самое, кроме изначально.

    
ответ дан Peter Ehrlich 16.02.2012 в 16:29
источник
2
ips = ['10.10.10.10','10.10.10.11','10.10.10.12']

ip = '10.10.10.10'
ips.include?(ip) => true

ip = '10.10.10.13'
ips.include?(ip) => false

проверьте Documentaion здесь

    
ответ дан dku.rajkumar 16.02.2012 в 16:29
источник