У меня есть массив, и я хочу создать хеш, чтобы я мог быстро спросить «есть ли 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)