У меня есть массив, и я хочу сделать хеш, чтобы я мог быстро спросить "есть X в массиве?".
В perl существует простой (и быстрый) способ сделать это:
my @array = qw( 1 2 3 );
my %hash;
@hash{@array} = undef;
Это генерирует хэш, который выглядит так:
{
1 => undef,
2 => undef,
3 => undef,
}
Лучшее, что я придумал в Ruby, это:
array = [1, 2, 3]
hash = Hash[array.map {|x| [x, nil]}]
который дает:
{1=>nil, 2=>nil, 3=>nil}
Есть ли лучший способ Ruby?
РЕДАКТИРОВАТЬ 1
Нет, Array.include? это не очень хорошая идея. Его медленный. Он выполняет запрос в O (n) вместо O (1). В моем массиве примеров было три элемента для краткости; предположим, что у фактического есть миллион элементов. Позвольте сделать небольшой бенчмаркинг:
#!/usr/bin/ruby -w
require 'benchmark'
array = (1..1_000_000).to_a
hash = Hash[array.map {|x| [x, nil]}]
Benchmark.bm(15) do |x|
x.report("Array.include?") { 1000.times { array.include?(500_000) } }
x.report("Hash.include?") { 1000.times { hash.include?(500_000) } }
end
Выдает:
user system total real
Array.include? 46.190000 0.160000 46.350000 ( 46.593477)
Hash.include? 0.000000 0.000000 0.000000 ( 0.000523)