題一:
給你一個整數(shù)數(shù)組arr图柏,請你幫忙統(tǒng)計數(shù)組中每個數(shù)的出現(xiàn)次數(shù)恐锣。如果每個數(shù)的出現(xiàn)次數(shù)都是獨(dú)一無二的挡逼,就返回true续语;否則返回false
示列1:輸入:arr = [1,2,2,1,1,3];輸出:true
解釋:在該數(shù)組中引谜,1出現(xiàn)了3次牍陌,2出現(xiàn)了2次,3 只出現(xiàn)了1次员咽。沒有兩個數(shù)的出現(xiàn)次數(shù)相同毒涧。
示列2:輸入:arr = [1,2];輸出:false
let subArr = [1, 2, 2, 1, 1, 3, 10, 10, 10, 10, 4, 4, 4, 4]
function sunFn(subArr) {
let subObj = subArr.reduce((obj, curKey) => {
obj[curKey] ? obj[curKey]++ : obj[curKey] =1
return obj
}, {})
return Object.values(subObj).length === [...new Set(Object.values(subObj))].length
}
console.log(sunFn(subArr)) //false
題二
不使用Set從數(shù)組中隨機(jī)取出N個不同元素
let subArr6 = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'a', 'b', 'c', 'i']
async function getNoRepetitionEle(n) {
subArr6 = subArr6.reduce((arr,item) => { //通過reduce進(jìn)行數(shù)組去重
return arr.includes(item) ? arr : [...arr, item]
},[])
// 獲取去重后的數(shù)組隨機(jī)下標(biāo)
let getIndexArr = () => {
if (n > subArr6.length) throw new Error('傳入?yún)?shù)超過去重后數(shù)組長度')
let iArr = []
for (let i = 0; i < n; i++) {
let index = Math.floor(Math.random() * subArr6.length) //隨機(jī)取數(shù)組的下標(biāo)
iArr.includes(index) ? i-- : iArr.push(index)
}
return iArr
}
let arrIndex = await getIndexArr(), eleArr = []
for (let iVal of arrIndex) {
eleArr.push(subArr6[iVal])
}
return eleArr
}
getNoRepetitionEle(6).then((ret) => {
console.log(ret) //["b", "c", "h", "i", "g", "e"] 隨機(jī)取出的6個不同元素
}).catch(err => {
alert(`${err.name}:${err.message}`)
})
題二感覺寫的有點(diǎn)復(fù)雜贝室,各位大佬有沒有更好的方案呢契讲?歡迎評論區(qū)留言!
題三
讓數(shù)組中指定索引的元素排到首位
let subArr3 = [1,2,3,4,5,6,7]
function setIndexFirst(key){
if(key > subArr3.length) throw new Error('參數(shù)錯誤')
subArr3.unshift(...subArr3.splice(subArr3.findIndex((val,i) => i === key), 1))
return subArr3
}
console.log(setIndexFirst(3)) //[4,1,2,3,5,6,7]
題四
請用一行代碼來判斷數(shù)組中的元素是否都相同?
通過every實現(xiàn):
let subArr7 = ['a','b','a','c']
let sub7 = subArr7.every((val, index) => { return val === subArr7[0] })
console.log(sub7) //false
every 方法:檢測數(shù)組中的元素是否滿足指定條件滑频,依次執(zhí)行數(shù)組元素捡偏,只要有一個不滿足就停止往下繼續(xù)執(zhí)行,返回false峡迷,所有元素滿足條件 返回 true
通過find實現(xiàn):
let subArr7 = ['a','a','a','a']
let sub7 = !subArr7.find((val,index,arr) => { return val !== arr[0]}) //不滿足條件 a !== a 返回undefined 取反 sub7則為true
console.log(sub7) //true
find方法:當(dāng)條件滿足時(val !== arr[0])返回true,并不再調(diào)用函數(shù)
不滿足則返回undefined
題五
一行代碼, 判斷數(shù)組中的值是連值. 比如[1,2,3,4,5]這樣的..
通過some方法實現(xiàn):
let subArr8 = [1, 2, 3, 4, 5, 6, 7, 8]
let sub8 = !subArr8.some((val,index,ary) => { return ary[index + 1] && ary[index + 1] - val !== 1 })
console.log(sub8) //true
只要有一個元素滿足條件就返回true 后面的元素就不再調(diào)用
沒有滿足條件都的元素 則返回false
日常動動腦银伟,生活沒煩惱!