我想知道一个数组是否是另一个数组的有序子集:
-
[1,2]
是一个有序子集[1,2,3]
-
[1,3]
是一个有序子集[1,2,3]
-
[2,1]
不是有序子集[1,2,3]
我找到了一些解决方案,但每个解决方案都忽略了顺序。到目前为止我见过的每个方法都会忽略数组的顺序:
[1,2,3] - [2,1] #=> [3]
[1,2,3] & [2,1] #=> [1,2]
[1,2,3].to_set.superset?([2,1].to_set) #=> true
Update:根据下面的讨论,我更新了我的问题。
b == a & b
这检查是否b
包含在a
以相同的顺序。
换句话说:一般来说,你有 B⊆A ⇔ B=A∩B。还有鲁比的Array#&
保留(左操作数的)顺序。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)