如果我有两个阵列,我试图找到他们的差异.. [1, 2, 3, 2, 6, 7] - [2, 1] 我明白了: [3, 6, 7] 但是,如果我翻转那些阵列 [2, 1] - [1, 2, 3, 2, 6, 7] 我明白了: [] 我的问题是,由于我的两个数组是动态
[1, 2, 3, 2, 6, 7] - [2, 1]
我明白了:
[3, 6, 7]
但是,如果我翻转那些阵列
[2, 1] - [1, 2, 3, 2, 6, 7]
我明白了:
[]
我的问题是,由于我的两个数组是动态的,我需要知道两个数组之间是否存在差异,无论它们的顺序如何.找到这个最简单的表达方式是什么?
你可以定义它:class Array def diff(o) (o - self) + (self - o) # alternatively: (o + self) - (o & self) end end [2, 1].diff [1, 2, 3, 2, 6, 7] # [3, 6, 7] [1, 2, 3, 2, 6, 7].diff [2, 1] # [3, 6, 7] [2, 3, 3, 1].diff [2, 4, 5] # [4, 5, 3, 3, 1] [2, 4, 5].diff [2, 3, 3, 1] # [3, 3, 1, 4, 5]
然而,正确的答案可能取决于你最终想要的,正如上面的第二个例子所示.
如果您只想要唯一值,则需要先将两个输入转换为集合,然后将结果作为数组返回:
class Array def diff(o) (o.to_set ^ to_set).to_a # or simply (o.to_set ^ self).to_a end end [2, 4, 5].diff [2, 3, 3, 1] # [4, 5, 3, 1]
(也可能有内置的Rails方法.)