var arr1 = [1,2,3,4,5,6,7]var arr2 = [3,5,7,9,12,14]求两个数组的去除重复元素后(指将两边的重复元素都删除,例如3重复,则在结果中不能有3,与数组去重不同)的合并的数组,即数组的并集减交集的部分,不知道这个部分有什么数学名称没有。求一个时间复杂度较低的算法?
1 回答
倚天杖
TA贡献1828条经验 获得超3个赞
用 set 做索引再遍历较短的 O(n)
var s1 = new Set(arr1)
var s2 = new Set(arr2)
if (s1.size > s2.size) { [s1, s2] = [s2, s1] } // 让 s1 较短
s1.forEach(n => s2.has(n) && (s1.delete(n), s2.delete(n)))
var result = [...s1, ...s2]
添加回答
举报
0/150
提交
取消