这个内容网上太多了,而且一般去重自己常用的也就是那一两种,这个就是为面试用的,我自己总结了几个觉得有意思的方法,放在下面
数组去重几种方式
const arr =[1,2,2,2,3,3,4,5,6,8,8]
ES6 Set 去重 (自用)
function unique1(arr) {
return [...new Set(arr)]
}
arr1 = unique1(arr)
console.log(arr1)
单循环 includes/index Of 都可以实现
function unique2(arr) {
const newArr = []
arr.forEach(item =>{
if (!newArr.includes(item)) newArr.push(item)
})
return newArr
}
arr2 = unique2(arr)
console.log(arr2)
单循环 使用reduce + includes
function unique3(arr) {
return arr.reduce((prev,cur) => prev.includes(cur) ? prev : [...prev,cur],[]);
}
arr3 = unique3(arr)
console.log(arr3)
单循环 使用sort
function unique4(arr) {
const newArr = []
arr = arr.sort()
for(let i =0;i<arr.length;i++) {
if(arr[i]!==arr[i+1]) newArr.push(arr[i])
}
return newArr
}
arr4 = unique4(arr)
console.log(arr4)
单循环 使用filter
// 单循环 使用filter
function unique5(arr) {
// 判断当前item在数组里第一次出现的索引位置和这个item自身的索引位置是否相同
return arr.filter((item,index)=>{return arr.indexOf(item)===index})
}
arr5 = unique5(arr)
console.log(arr5)
双循环 (感觉双循环好没用啊)
function unique6(arr) {
for(let i =0;i<arr.length;i++) {
for(let j =i+1;j<arr.length;j++) {
if(arr[i]===arr[j]) {
arr.splice(j,1)
j-- //splice少了一位,所以j也要退回来一位
}
}
}
return arr
}
arr6 = unique6(arr)
console.log(arr6)
获取数组最大值几种方式
const arr = [1,2,6,3,9,13,11,3,8]
使用sort()方法
function maxNumber(arr) {
const arr1 = arr.sort((a,b)=> b - a)
return arr1[0]
}
const number = maxNumber(arr)
console.log(number)
使用for循环
function maxNumber1(arr) {
let maxNumber = arr[0]
arr.forEach(item => {
maxNumber = item > maxNumber ?item :maxNumber
})
return maxNumber
}
const number1 = maxNumber1(arr)
console.log(number1)
使用reduce
function maxNumber2(arr) {
const maxNumber = arr.reduce((a,b)=> a > b ? a : b)
return maxNumber
}
const number2 = maxNumber2(arr)
console.log(number2)
使用Math.max
function maxNumber4(arr) {
const maxNumber = Math.max(...arr)
return maxNumber
}
const number4 = maxNumber4(arr)
console.log(number4)