设A和B为两个集合。我正在寻找一种 非常 快速或优雅的方法来计算它们之间的设置差异(A - B或A \B,取决于您的偏好)。如标题所示,这两组存储和存储为Javascript数组。
A
B
A - B
A \B
笔记:
编辑: 我注意到有关包含重复元素的集合的评论。当我说“设置”时,我指的是数学定义,这意味着(除其他外)它们不包含重复的元素。
如果不知道这是否最有效,但可能最短
A = [1, 2, 3, 4]; B = [1, 3, 4, 7]; diff = A.filter(function(x) { return B.indexOf(x) < 0 }) console.log(diff);
更新到ES6:
A = [1, 2, 3, 4]; B = [1, 3, 4, 7]; diff = A.filter(x => !B.includes(x) ); console.log(diff);