如何删除Javascript中重复的排序数组? 我尝试过在新集合上使用传播语法制作一个新数组,但这看起来极其复杂,并迫使我的结果集看起来像这样:
[ [ '-', '1', ',', '0', ',', '1' ],
[ '-', '1', ',', '-', '1', ',', '2' ] ]
[ [ '-', '1', ',', '0', ',', '1' ],
[ '-', '1', ',', '-', '1', ',', '2' ] ]
[ [ '0', ',', '0', ',', '0' ] ]
[ [ '0', ',', '0', ',', '0' ] ]
[ [ '-', '4', ',', '-', '2', ',', '6' ],
[ '-', '4', ',', '0', ',', '4' ],
[ '-', '4', ',', '1', ',', '3' ],
[ '-', '4', ',', '2', ',', '2' ],
[ '-', '2', ',', '-', '2', ',', '4' ],
[ '-', '2', ',', '0', ',', '2' ] ]
[ [ '-', '4', ',', '-', '2', ',', '6' ],
[ '-', '4', ',', '0', ',', '4' ],
[ '-', '4', ',', '1', ',', '3' ],
[ '-', '4', ',', '2', ',', '2' ],
[ '-', '2', ',', '-', '2', ',', '4' ],
[ '-', '2', ',', '0', ',', '2' ] ]
或
[ [ '-1,0,1' ], [ '-1,-1,2' ] ]
[ [ '-1,0,1' ], [ '-1,-1,2' ] ]
[ [ '0,0,0' ] ]
[ [ '0,0,0' ] ]
[ [ '-4,-2,6' ],
[ '-4,0,4' ],
[ '-4,1,3' ],
[ '-4,2,2' ],
[ '-2,-2,4' ],
[ '-2,0,2' ] ]
[ [ '-4,-2,6' ],
[ '-4,0,4' ],
[ '-4,1,3' ],
[ '-4,2,2' ],
[ '-2,-2,4' ],
[ '-2,0,2' ] ]
请注意,这些是在我将它们设置为字符串之后。 该集合不会删除重复的排序数组,因为它们是不同的对象。
这是代码。
var threeSum = function (arr) {
let map = new Map();
for (let i = 0; i < arr.length; i++) {
let num = arr[i];
if (map.has(num)) {
map.get(num).push(i);
}
else {
map.set(num, [i]);
}
}
const results = [];
for (let i = 0; i < arr.length; i++) {
for (let j = i + 1; j < arr.length; j++) {
let diff = (arr[i] + arr[j]);
diff = (diff == 0) ? diff: diff * -1;
if (map.has(diff)) {
let mArr = map.get(diff);
for (let k = 0; k < mArr.length; k++) {
if (mArr[k] != i && mArr[k] != j ) {
results.push([arr[i], arr[j], diff]);
}
}
}
}
}
results.forEach((value) => {
value.sort((a, b) => { return a - b });
});
let newResults = results.filter((val, idx, arr) => {
/// how do i do this
})
console.log(newResults);
return newResults;
}
console.log(threeSum([-1, 0, 1, 2, -1, -4]));
console.log(threeSum([0,0,0,0]));
console.log(threeSum([-4,-2,-2,-2,0,1,2,2,2,3,3,4,4,6,6]));
答案 0 :(得分:0)
set 非常适合此任务。集保持其所有元素都是唯一的条件。这是完成任务的方式:
let set = new Set(results.map(result => JSON.stringify(result))
Array.from(set).map(elem => JSON.parse(elem))
答案 1 :(得分:0)
results
的形成中可能还存在其他一些问题,但是要简单地从已排序的数组中获取唯一项:
定义一个函数来检查数组a
和b
是否等于前L
个索引(因为a == b
本身不起作用):
let equal = function(a, b, L){
for (let i=0; i<L; ++i) {
if (a[i] != b[i]) return false;
}
return true;
}
在检测到新项目时推送到newResults
。
var threeSum(...
...
if (results.length == 0){
return [];
}
newResults = [results[0]];
for (let i = 1; i < results.length; ++i){
if (!equal(results[i], newResults[newResults.length - 1], 3)){
newResults.push(results[i]);
}
}
return newResults;
}
但是可能还有其他一些问题,例如遍历map.get(diff)
的所有项,尽管第一个项mArr[0]
是键(其余都是值)