1. Set
const arr = [11, 11, 22, 33, 44, 55, 22, 33]
function getUniqueArray(arr) {
const res = [...new Set(arr)]
return res
}
console.log(getUniqueArray(arr));
2. filter
const test = [1, 1, 2, 3, 3, 4, 5]
function getUniqueArray(arr) {
const res = arr.filter((item, index) => {
return arr.indexOf(item) === index
})
return res
}
console.log(getUniqueArray(test));
3.reduce
const test = [1, 1, 2, 3, 3, 4, 5]
function getUniqueArray(arr) {
const res = arr.reduce((pre, item) => {
return pre.includes(item) ? pre : [...pre, item]
}, [])
return res
}
console.log(getUniqueArray(test));
4. 双循环+splice
const arr = [11, 11, 11, 22, 33, 44, 55, 22, 33]
function getUniqueArray(arr) {
const res = []
for (let i = 0; i < arr.length; i++) {
for (let j = i + 1; j < arr.length; j++) {
if (arr[i] === arr[j]) {
arr.splice(i, 1);
j--
}
}
res.push(arr[i])
}
return res
}
console.log(getUniqueArray(arr));
5. 双循环破解
const test = [1, 1, 1, 2, 2, 3, 3, 4, 5]
function getUniqueArray(arr) {
var res = []
for (let i = 0; i < arr.length; i++) {
for (let j = i + 1; j < arr.length; j++) {
if (arr[i] === arr[j]) {
i++;
}
}
res.push(arr[i])
}
return res
}
console.log(getUniqueArray(test));
6. 利用对象key
const test = [21, 21, 2, 3, 3, 4, 5]
function getUniqueArray(arr) {
const res = {}
arr.forEach((item, index) => {
res[arr[index]] = '无所谓'
})
return Object.keys(res).map(item => ~~item)
}
console.log(getUniqueArray(test));
7. 排序
const test = [11, 11, 11, 2, 3, 3, 4, 5]
function fast(arr) {
if (arr.length < 2) return array
var point = arr[arr.length - 1]
var left = arr.filter(item => item < point)
var right = arr.filter(item => item > point)
return [...fast(left), point, ...fast(right)]
}
function getUniqueArray(arr) {
var res = []
for (let i = 0; i < arr.length; i++) {
if (arr[i] !== arr[i + 1]) {
res.push(arr[i])
}
}
console.log(res);
}
getUniqueArray(fast(test))