码迷,mamicode.com
首页 > 其他好文 > 详细

Ruby: Count unique elements and their occurences in an array

时间:2015-08-20 12:49:40      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:

Is there a method in Ruby that takes an array, and counts all unique elements and their occurrences and passes them back as a hash?

For example

  [‘A‘,‘A‘,‘A‘,‘A‘,‘B‘,‘B‘,‘C‘].method
> {‘A‘ => 4, ‘B‘ => 2, ‘C‘ => 1}

Something like that.

[‘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‘]
Hash[src.group_by { |x| x }.map { |k, v| [k, v.length] }]

counts = Hash.new(0)
[‘A‘,‘A‘,‘A‘,‘A‘,‘B‘,‘B‘,‘C‘].each { |name| counts[name] += 1 }
counts   => {"A"=>4, "B"=>2, "C"=>1}


[‘A‘,‘A‘,‘A‘,‘A‘,‘B‘,‘B‘,‘C‘].each_with_object(Hash.new(0)) { |l, o| o[l] += 1 }

This is the easiest readable for me:

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

Or here is another solution with reduce method:

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

Or:

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


Ruby: Count unique elements and their occurences in an array

标签:

原文地址:http://www.cnblogs.com/bhlsheji/p/4744518.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!