说在前面
🎈不知道大家对于算法的学习是一个怎样的心态呢?为了面试还是因为兴趣?不管是出于什么原因,算法学习需要持续保持。
题目描述
给定一个整型参数 n,请你编写并返回一个 counter 函数。这个 counter 函数最初返回 n,每次调用它时会返回前一个值加 1 的值 ( n , n + 1 , n + 2 ,等等)。
示例 1:
输入: n = 10 ["call","call","call"] 输出:[10,11,12] 解释: counter() = 10 // 第一次调用 counter(),返回 n。 counter() = 11 // 返回上次调用的值加 1。 counter() = 12 // 返回上次调用的值加 1。
示例 2:
输入: n = -2 ["call","call","call","call","call"] 输出:[-2,-1,0,1,2] 解释:counter() 最初返回 -2。然后在每个后续调用后增加 1。
提示:
- -1000 <= n <= 1000
- 0 <= calls.length <= 1000
- calls[i] === “call”
解题思路
函数 counter 是一个闭包,它可以访问 createCounter 函数中的局部变量 n。每次调用 counter 函数时,它会返回 n 的当前值,并将 n 的值加一。
示例中给出了如何使用 createCounter 函数创建一个计数器。通过调用 createCounter(10),我们得到一个初始值为 10 的计数器。每次调用 counter(),它会返回计数器的当前值,并将计数器的值增加 1。
按照示例,第一次调用 counter() 将返回 10,第二次调用返回 11,第三次调用返回 12,依此类推。
这种方式可以用于创建具有私有状态的函数,通过闭包来保存局部变量的值,并在每次调用时更新该值。
AC代码
/** * @param {number} n * @return {Function} counter */ var createCounter = function(n) { return function() { return n++; }; }; /** * const counter = createCounter(10) * counter() // 10 * counter() // 11 * counter() // 12 */
公众号
关注公众号『前端也能这么有趣
』,获取更多有趣内容。
说在后面
🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『
前端也能这么有趣
』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。