计算没有LOOPS的单词

时间:2012-02-25 21:58:34

标签: ruby hash count mapreduce words

我对Ruby有疑问:

给定一个输入字符串,我需要返回一个哈希,其键是字符串中的单词,其值是每个单词出现的次数。重要提示:我不能使用for循环。

示例:“今天是一天,一个日出” 输出:{'今天'=> 1,'是'=> 1,'a'=> 2,'day'=> 1,'sunrise'=> 1}

你能帮助我吗?

3 个答案:

答案 0 :(得分:5)

尝试这样的事情:

def count_words_without_loops(string)
  res = Hash.new(0)
  string.downcase.scan(/\w+/).map{|word| res[word] = string.downcase.scan(/\b#{word}\b/).size}
  return res
end

答案 1 :(得分:5)

h = Hash.new(0)
"Today is a day, a sunrise".scan(/\w+/) do |w|
  h[w] += 1
end

p h # {"Today"=>1, "is"=>1, "a"=>2, "day"=>1, "sunrise"=>1}

答案 2 :(得分:0)

如果你有一个for循环约束,去递归!
只是不要忘记停止条件。