def self.foo
[
["a","aa"],
["b","bb"],
]
end
给定“a”,我应该能够检索“aa”给定“bb”,我应该能够检索“b”
我该怎么做呢?
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"
我会创建自己的“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