力扣之2629.复合函数(reduceRight )

力扣之2629.复合函数(reduceRight )_第1张图片

/**
 * @param {Function[]} functions
 * @return {Function}
 */
var compose = function(functions) {
    
	return function(x) {
       return functions.reduceRight((result, func) => func(result), x);

    }
};

/**
 * const fn = compose([x => x + 1, x => 2 * x])
 * fn(4) // 9
 */

 说明:

  1. reduceRight 的第一次迭代:

    • func 是数组中的最后一个函数 x => 2 * x
    • result 初始值是 4(传入 fn 的参数)。
    • func(result) 即执行 x => 2 * x 函数,得到 2 * 4 = 8,这个值成为下一次迭代的 result
  2. reduceRight 的第二次迭代:

    • func 是数组中的第一个函数 x => x + 1
    • result 是上一次迭代的结果 8
    • func(result) 即执行 x => x + 1 函数,得到 8 + 1 = 9

最终,fn(4) 的调用输出 9,这是因为整个 compose 函数依次执行了数组中的函数,并将结果传递给下一个函数。

力扣之2629.复合函数(reduceRight )_第2张图片

你可能感兴趣的:(力扣,leetcode,javascript,算法)