首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >自动记忆的天真实现

自动记忆的天真实现
EN

Code Review用户
提问于 2019-03-02 22:58:00
回答 1查看 38关注 0票数 1

我编写了代码(天真地)来执行自动回忆录。我试图用函数式编程方式编写它,因此没有使用任何全局变量。

我的代码

代码语言:javascript
复制
def naive_memoise(caches):
    def memoise(f):
        nonlocal caches
        def mem_f(n):
            nonlocal caches, f
            if f not in caches:
                caches[f] = {}
            if n not in caches[f]:
                caches[f][n] = f(n)
            return caches[f][n]
        return mem_f
    return memoise

示例使用

代码语言:javascript
复制
def fib(n):
    if n in [0, 1]:
        return n
    return  fib(n - 2) + fib(n - 1)

mem = naive_memoise({})
fib = mem(fib)
EN

回答 1

Code Review用户

回答已采纳

发布于 2019-03-02 23:27:50

这在我看来很好,我没有什么重要的补充。

  • 这里不需要nonlocal
  • 在代码示例中,可以使用@decorator语法。
  • 也许您可以编写一些更通用的东西,而不仅仅是接受单个参数的函数。
票数 1
EN
页面原文内容由Code Review提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://codereview.stackexchange.com/questions/214618

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档