ruby一道循环算法题:不同ID出现次数

需求:

从文件中统计不同ID在两种条件下出现的次数。

例如,文件中数据如下:

post  10001
get  10001
get  10002
post  10001
post  10002
...

在Ruby代码中用Hash保存取到的值:

data = Hash.new{|h, key| h[key] = []}
data[:post] << #value
data[:get] << #value
=begin 期待结果
data[:post] => [2, 1]。10001 的 post 出现次数:2;10002 的 post 出现次数:1
data[:get] => [1, 1]。10001 的 get 出现次数:1;10002 的 get 出现次数:1
=end

循环遍历文件,分别对不同ID的两种统计,如何达到正确的效果呢?


注:文件中ID不固定,有若干个,生成的相应形式为:

data[:post] => [2, 1, n] # n为ID的第n次出现
阅读 4.6k
1 个回答

我建议这样


data[:post]=[]; data[:get]=[]
data[:post][value]+=1
data[:get][value]+=1
=begin 结果
data[:post][x] => post x 出现的次数
data[:get][x] => get x 出现的次数
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题