黑马程序员技术交流社区
标题: 【上海校区】面试题之数组去重 [打印本页]
作者: 爱编码的J 时间: 2020-1-2 13:11
标题: 【上海校区】面试题之数组去重
数组去重是面试经常遇到的,命中率高达85%+。下给大家整理出一些应对数组去重的方案
1、使用ES6的Set去重
[JavaScript] 纯文本查看 复制代码
function distinct(arr) {
return Array.from(new Set(arr));
}
2、使用ES6的Set去重(超级简化版)
[JavaScript] 纯文本查看 复制代码
[...new Set(arr)]
3、使用splice配合两重for循环去重
[JavaScript] 纯文本查看 复制代码
function distinct(arr) {
for(let i = 0; i < arr.length; i++) {
for(let j = i + 1; j < arr.length; j++) {
if(arr === arr[j]) {
arr.splice(j, 1);
j--;
}
}
}
return arr;
}
4、使用for循环配合indexOf去重
[JavaScript] 纯文本查看 复制代码
function distinct(arr) {
let newArr = [];
for(let i = 0; i < arr.length; i++) {
if(newArr.indexOf(arr) === -1) {
newArr.push(arr);
}
}
return newArr;
}
5、使用for循环配合sort排序去重
[JavaScript] 纯文本查看 复制代码
function distinct(arr) {
arr = arr.sort();
let newArr = [];
for(let i = 0; i < arr.length; i++) {
if(arr !== arr[i-1]) {
newArr.push(arr);
}
}
return newArr;
}
6、使用for循环配合includes去重
[JavaScript] 纯文本查看 复制代码
function distinct(arr) {
let newArr = [];
for(let i = 0; i < arr.length; i++) {
if(!newArr.includes(arr)) {
newArr.push(arr);
}
}
return newArr;
}
7、使用filter配合indexOf去重
[JavaScript] 纯文本查看 复制代码
function distinct(arr) {
return arr.filter((item,index, arr) => arr.indexOf(item) === index);
}
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) |
黑马程序员IT技术论坛 X3.2 |