1 回答

TA貢獻(xiàn)1876條經(jīng)驗 獲得超7個贊
由于數(shù)組長度未知,最好的方法是使用遞歸:
function conc(input) {
const output = [];
function _conc(input, partial) {
if (input.length === 0) {
return output.push(partial);
}
const [first, ...rest] = input;
first.forEach(itm => {
_conc(rest, partial + "." + itm)
});
}
_conc(input, "");
return output;
}
const input = [
['a','b',],
['c','d'],
['e']
]
console.log(conc(input))
或與flatMap:
function conc(input) {
const [first, ...rest] = input;
return rest.length === 0
? first.map(itm => "." + itm)
: first.flatMap(itm => conc(rest).map(_itm => "." + itm + _itm));
}
const input = [
['a','b',],
['c','d'],
['e']
]
console.log(conc(input))
或減少:
const input = [
['a','b',],
['c','d'],
['e']
]
console.log(
input.reduce((acc, a) => acc.flatMap(i1 => a.map(i2 => i1 + "." + i2)), [""])
)
添加回答
舉報