2

背景:在 Ruby 中,我有一个如下所示的二维数组:

count[[english_word, french_word]] = ...
pp count
{["my", "une"]=>0.0,
 ["my", "voiture"]=>0.2,
 ["red", "maison"]=>0.9,
...
}

(我这样做的原因不是count[english_word][french_word]我不确定如何解决 Undef 错误,我在 Stack Overflow 上看到了建议的这种语法)

我已经用一对嵌套循环填充了数据结构,使用 aenglish_vocabfrench_vocab所有单词的数组。

问题:我希望能够获得给定英语单词的最大值。

english_word = 'foo'
max_count = 0
french_vocab.each do |french_word|
   count = count[[english_word, french_word]]
   if count > max_count
       max_count = count
   end
end

我可以用一个简单的嵌套 for 循环来做到这一点,但我想知道是否有更好的 Ruby-ish 方式来做同样的事情?

4

1 回答 1

2

我认为这比你想象的要容易得多。

hash = {
  ["my", "une"]=>0.0,
  ["my", "voiture"]=>0.2,
  ["red", "maison"]=>0.9,
}

puts hash.find_all{|a| a[0][0] == 'my' }.max[1]
于 2010-08-29T06:45:09.633 回答