我有一个数组,我想做一个散列,这样我就可以快速询问“数组中有 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)