我在使用reduce函数时遇到了语法问题。我有一个以下格式的哈希表:
H = {"Key1" => 1, "Key2" => 2}
我想使用reduce函数来计算这个函数中值的总和。
类似以下的内容:
H.reduce(0) {|memo, elem| memo+=elem}
我知道这是错的。我不明白如何将elem作为哈希表的值。
elem
包含该值:H.reduce(0) {|memo, (key, val)| memo + val}
memo + val
,避免让人们认为更新memo
是有帮助的。 - Ludovic Kuty如果你可以接受哈希表为空时返回nil
,那么请使用Enumerable#reduce
:
H.values.reduce(:+) # => 3
Hash.new.values.reduce(:+) # => nil
若要在哈希为空时安全地获得0
,请使用:
H.values.reduce(0) { |sum,x| sum + x } # or...
H.reduce(0) { |sum,(key,val)| sum + val } # ...if you need to inspect the key
这里是一个快速的基准测试,只是为了好玩。请注意,仅缩减值似乎比从键/值对中缩减值要稍微快一些:
user system total real
H.values.reduce(:+) 4.510000 0.080000 4.590000 ( 4.595229)
H.values.reduce(0) {...} 4.660000 0.080000 4.740000 ( 4.739708)
H.reduce(0) {...} 5.160000 0.070000 5.230000 ( 5.241916)
require 'benchmark'
size = 1_000
hash = Hash[* Array.new(size*2) { rand } ]
N=10_000
Benchmark.bm(24) do |x|
x.report('H.values.reduce(:+)') { N.times { hash.dup.values.reduce(:+) } }
x.report('H.values.reduce(0) {...}') { N.times { hash.dup.values.reduce(0) { |sum,x| sum + x } } }
x.report('H.reduce(0) {...}') { N.times { hash.dup.reduce(0) { |sum,(_,v)| sum + v } } }
end
试试这个:
H.reduce(0) { |memo, elem| memo += elem[1] }
或者
H.reduce(0) { |memo, (key, value)| memo += value }
h = {"Key1" => 1, "Key2" => 2}
h.values.inject(0){|f,v| f += v.to_i }
# => 3
或者
h.values.inject(:+)
# => 3
values = H.map do |k, v|
# some complex logic here
end
values.reduce(:+)
如果数组可能为空,则使用values.reduce(0, :+)
。