假设我们有“深度哈希”,例如:
b = {1 => {2 => {} }, 4 => {} }
a = {1 => {2 => {3 => {} }}, 4 => {}, 5 => "123" }
或者
b = {1 => {children: {2 => {children: false} }}}
a = {1 => {name: "name", surname:"sur", children: {2 => {name: "name", surname:"sur", children: false}}}, 3 => {}}
a
包括b
但反之亦然;
这是我的尝试:
class Hash
def >=(b)
eq ||= true
b.each do |k, v|
if !(self.include? k)
eq = false
elsif ( ((self[k]&&v).is_a? Hash) && !((v||self[k]).empty?) )
self[k]>=v
end
end
return eq
end
end
a >= b # true
b >= a # false
精简版:
class Hash
def >=(b)
eq = true
b.each { |k, v| eq &= !(self.include? k) ? false : ( ( ((self[k]&&v).is_a? Hash) && !((v||self[k]).empty?) ) ? self[k]>=v : true)}
return eq
end
end
我的问题:有没有更优雅的方式来做到这一点?