如何从任意顺序的两个动态数组中提取出完全不同的元素?
- 内容介绍
- 文章标签
- 相关推荐
本文共计435个文字,预计阅读时间需要2分钟。
如果我有两个列表,我尝试图找它们的差异。例如,[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方法.)
本文共计435个文字,预计阅读时间需要2分钟。
如果我有两个列表,我尝试图找它们的差异。例如,[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方法.)

