前端之家收集整理的这篇文章主要介绍了
红宝石:如何在数组中找到非唯一的元素并打印每个元素的数量?,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有
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}" }
原文链接:https://www.f2er.com/ruby/272382.html