标签:meta 面试题 type item isa har while isarray image
题目描述:实现一个方法使多维数组变成一维数组
最常见的递归版本如下:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script>
    /**
     * 题目描述:实现一个方法使多维数组变成一维数组
     最常见的递归版本如下:
     */
    function flatter(arr) {
        if (!arr.length) return;
        return arr.reduce(
            (pre, cur) =>
                Array.isArray(cur) ? [...pre, ...flatter(cur)]
                : [...pre, cur], []
        )
    }
    console.log(flatter([1, 2, [1, [4, 5, [5, 6, 7, [8, 9]]]]]));
    //  [1, 2, 1, 4, 5, 5, 6, 7, 8, 9]
</script>
</body>
</html>

扩展思考:能用迭代的思路去实现吗?
    function flatter(arr) {
        if (!arr.length) return;
        while(arr.some((item) => Array.isArray(item))) {
            arr = [].concat(...arr);
        }
        return arr;
    }
    console.log(flatter([1, 2, [1, [4, 5, [5, 6, 7, [8, 9]]]]]));

标签:meta 面试题 type item isa har while isarray image
原文地址:https://www.cnblogs.com/lvhanghmm/p/14907292.html