最佳答案
我试图从 Ruby 中的散列表中获取第一个键和值键。我不知道散列的键值,因为它被传递给方法。我找不到任何地方在线如何找到第一个键/值作为一个单独的哈希表。
我认为 hash[0]
只是尝试找到一个名称为0的元素,当我运行代码时它只返回 nil
。
我知道我可以找到键名和值,然后从他们创建一个新的散列,但我不知道是否有一个更简单的方法来做到这一点,所以我得到一个散列马上。
我的原则是:
def rps_game_winner(game)
rock_in_hash = game.invert['R']
paper_in_hash = game.invert['P']
scissors_in_hash = game.invert['S']
if(rock_in_hash)
if(paper_in_hash)
return paper_in_hash;
elsif(scissors_in_hash)
return rock_in_hash
end
elsif(paper_in_hash)
if(rock_in_hash)
return paper_in_hash
elsif(scissors_in_hash)
return scissors_in_hash
end
end
key = game.keys[-1]
value = game.values[-1]
winner = {key => value}
return winner
end
game_one = { "Bob" => 'P', "Jim" => 'P' }
puts rps_game_winner(game_one)
这给了我正确的结果问题是我不明白为什么它是 -1而不是0。 我希望有一个更好的方法来获得哈希表的第一个键/值对,而不是使用从前一个表中检索到的键和值创建新的哈希表。