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 

这对我来说是最简单的:

 src = ['A','A','A','A','B','B','C'] src.group_by(&:to_s).map { |a| [a[0], a[1].count] }.to_h 

或者这是另一种使用reduce方法的解决方案:

 src.reduce({}) { |b, a| b.merge({a => (b[a] || 0) + 1}) } 

要么:

 src.reduce(Hash.new(0)) { |b, a| b.merge({a => b[a] + 1}) } 

以下应该做:

 counts = Hash.new(0) ['A','A','A','A','B','B','C'].each { |name| counts[name] += 1 } 

counts => {“A”=> 4,“B”=> 2,“C”=> 1}

从评论中,下面一个class轮也做同样的事情:

 ['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] }]