Ruby中是否有一个方法需要一个数组,并计算所有独特元素及其出现并将它们作为散列传回?Ruby:计算数组中的独特元素及其出现
例如
['A','A','A','A','B','B','C'].method
> {'A' => 4, 'B' => 2, 'C' => 1}
类似的东西。
Ruby中是否有一个方法需要一个数组,并计算所有独特元素及其出现并将它们作为散列传回?Ruby:计算数组中的独特元素及其出现
例如
['A','A','A','A','B','B','C'].method
> {'A' => 4, 'B' => 2, 'C' => 1}
类似的东西。
['A','A','A','A','B','B','C'].group_by{|e| e}.map{|k, v| [k, v.length]}.to_h
以下应该做的:
counts = Hash.new(0)
['A','A','A','A','B','B','C'].each { |name| counts[name] += 1 }
计数 => { “A”=> 4, “B”=> 2, “C”=> 1}
从评论,下面一个衬垫也做同样的:
['A','A','A','A','B','B','C'].each_with_object(Hash.new(0)) { |l, o| o[l] += 1 }
不是。如果你想要一个班轮解决方案,或许这一次将是最短的(虽然不是最有效的):
src = ['A','A','A','A','B','B','C']
Hash[src.group_by { |x| x }.map { |k, v| [k, v.length] }]
这是最简单可读对我来说:
src = ['A','A','A','A','B','B','C']
src.group_by(&:to_s).map { |a| [a[0], a[1].count] }.to_h
或者这里是另一种解决方案减少方法:
src.reduce({}) { |b, a| b.merge({a => (b[a] || 0) + 1}) }
或者:
src.reduce(Hash.new(0)) { |b, a| b.merge({a => b[a] + 1}) }
@GreyCat一个简单的ruby问题应该默认为最新版本。当使用旧版本时,应该特别提及。对你来说,电视机是指黑色和白色真空管操作的电视机吗?我需要特别说“彩电”来区分黑白电视吗? – sawa