es6의 flat 및 Set 이해
//
function flatten (arr) {
const flattend = []
arr.forEach(v => {
if (Array.isArray(v))
flattend.push(...flatten(v))
else flattend.push(v)
})
return flattend
}
// example
const arr = [1, [2, 3], [2], [1, [2]]]
console.log(flatten(arr))
// [1, 2, 3, 2, 1, 2]
console.log([...new Set(flatten(arr))])
// [1, 2, 3]
console.log([...new Set(arr.flat())])
// [1, 2, 3, [2]]
console.log([...new Set(arr.flat(Infinity))])
// [1, 2, 3]
//
function flatten(arr) {
while (arr.some(item => Array.isArray(item))) {
arr = [].concat(...arr)
}
return arr
}
면접 문제: 다음 그룹으로 알고 있습니다.
var arr = [ [1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, [14] ] ] ], 10];
프로그램을 작성하여 수조를 편평하게 하고 그 중의 일부 데이터를 제외하면, 최종적으로 승급하고 중복되지 않는 수조를 얻을 수 있다
// es6
var arr = [ [1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, [14] ] ] ], 10];
[...new Set(arr.flat(Infinity).sort((a, b) => a-b))]
// es5
Array.prototype.flat = function () {
return [].concat(...this.map(v => (v instanceof Array) ? v.flat(v) : [v]))
}
Array.prototype.set = function() {
const stack = []
this.forEach(v => stack.indexOf(v) < 0 && stack.push(v))
return stack
}
arr.flat().set().sort((a, b) => a - b)
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.