0
  def self.foo
    [
      ["a","aa"],
      ["b","bb"],
    ]
  end

给定“a”,我应该能够检索“aa”给定“bb”,我应该能够检索“b”

我该怎么做呢?

4

3 回答 3

2

assocrassoc是你的朋友:

ar = [
  ["a","aa"],
  ["b","bb"],
]
p ar.assoc("a").last #=> "aa"
p ar.rassoc("bb").first #=> "b"
于 2012-09-12T13:56:08.837 回答
0
Hash[self.foo].invert["bb"] #=> "b"
Hash[self.foo]["a"] #=> "aa"

Hash[]将数组转换为哈希

Hash#invert反转散列,因此所有值都映射到键

如果你想两者都做:

Hash[self.foo]["bb"] or Hash[self.foo].invert["bb"] #=> "b"
于 2012-09-12T13:28:23.983 回答
0

我会创建自己的“bimap”实现,可能类似于:

class Bimap < Hash
  alias :__put__ :[]=
  def []=(key,value)
    __put__(key,value)
    __put__(value,key)
  end

  alias :__size__ :size
  def size
    __size__ / 2
  end

  # ...any other Hash methods to reimplement?
end
于 2012-09-12T14:18:22.223 回答