function *flat(array) {
for (const item of array) {
if (Array.isArray(item)) {
yield* flatMap(item);
}else {
yield item;
}
}
}
function flat2(arr) {
const res = [];
const fmFunc = function(array) {
for (const item of array) {
if (Array.isArray(item)) {
fmFunc(item);
} else {
res.push(item);
}
}
}
fmFunc(arr);
return res;
}
function flat3(arr) {
return arr.reduce((prev, cur) => {
if (Array.isArray(cur)) {
return prev.concat(flat3(cur));
} else {
return prev.concat(cur);
}
}, [])
}
function flat4(arr) {
const res = [];
const stack = arr.reverse().slice();
while (stack.length > 0) {
const top = stack.pop();
if (Array.isArray(top)) {
stack.push(...top.reverse());
} else {
res.push(top);
}
}
return res;
}
const darr = [[1, 2, 3], [4], [6, [7, 8, 9]]];
const farr = [...flat(darr)];
console.log(`flatArr ${farr}`);
const farr2 = flat2(darr);
console.log(`flatArr2 ${farr2}`);
const farr3 = flat3(darr);
console.log(`flatArr3 ${farr3}`);
const farr4 = flat4(darr);
console.log(`flatArr4 ${farr4}`);
网友评论