红宝石:如何在数组中找到非唯一的元素并打印每个元素的数量?

我有
a = ["a","d","c","b","c"]

并需要打印类似的东西(按出现次数排序)

c:3
b:2

我明白第一部分(发现非唯一)是:

b = a.select{ |e| a.count(e) > 1 }
=> ["c","c"]

要么

puts b.select{|e,c| [e,a.count(e)] }.uniq

c
b

如何输出一个非唯一的数量排序次数

解决方法

puts a.uniq.
       map { | e | [a.count(e),e] }.
       select { | c,_ | c > 1 }.
       sort.reverse.
       map { | c,e | "#{e}:#{c}" }

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...