What is memoization and how can I use it in Python?(什么是 memoization 以及如何在 Python 中使用它?)
问题描述
我刚开始使用 Python,我不知道 memoization 是什么以及如何使用它.另外,我可以举一个简化的例子吗?
I just started Python and I've got no idea what memoization is and how to use it. Also, may I have a simplified example?
推荐答案
记忆化是指根据方法输入记忆(记忆化"→备忘录"→被记忆)方法调用的结果,然后返回记忆的结果而不是再次计算结果.您可以将其视为方法结果的缓存.有关详细信息,请参阅第 387 页以了解 Introduction To Algorithms (3e), Cormen 等人中的定义.
Memoization effectively refers to remembering ("memoization" → "memorandum" → to be remembered) results of method calls based on the method inputs and then returning the remembered result rather than computing the result again. You can think of it as a cache for method results. For further details, see page 387 for the definition in Introduction To Algorithms (3e), Cormen et al.
在 Python 中使用 memoization 计算阶乘的简单示例如下所示:
A simple example for computing factorials using memoization in Python would be something like this:
factorial_memo = {}
def factorial(k):
if k < 2: return 1
if k not in factorial_memo:
factorial_memo[k] = k * factorial(k-1)
return factorial_memo[k]
你可以再复杂一点,把memoization过程封装成一个类:
You can get more complicated and encapsulate the memoization process into a class:
class Memoize:
def __init__(self, f):
self.f = f
self.memo = {}
def __call__(self, *args):
if not args in self.memo:
self.memo[args] = self.f(*args)
#Warning: You may wish to do a deepcopy here if returning objects
return self.memo[args]
然后:
def factorial(k):
if k < 2: return 1
return k * factorial(k - 1)
factorial = Memoize(factorial)
在 Python 2.4 中添加了一个名为decorators"的功能现在允许您简单地编写以下代码来完成相同的事情:
A feature known as "decorators" was added in Python 2.4 which allow you to now simply write the following to accomplish the same thing:
@Memoize
def factorial(k):
if k < 2: return 1
return k * factorial(k - 1)
Python 装饰器库 有一个类似的装饰器,称为 memoized
比此处显示的 Memoize
类更健壮.
The Python Decorator Library has a similar decorator called memoized
that is slightly more robust than the Memoize
class shown here.
这篇关于什么是 memoization 以及如何在 Python 中使用它?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:什么是 memoization 以及如何在 Python 中使用它?


- 使用Heroku上托管的Selenium登录Instagram时,找不到元素';用户名'; 2022-01-01
- padding='same' 转换为 PyTorch padding=# 2022-01-01
- pytorch 中的自适应池是如何工作的? 2022-07-12
- 如何在 Python 的元组列表中对每个元组中的第一个值求和? 2022-01-01
- 分析异常:路径不存在:dbfs:/databricks/python/lib/python3.7/site-packages/sampleFolder/data; 2022-01-01
- 沿轴计算直方图 2022-01-01
- 如何将一个类的函数分成多个文件? 2022-01-01
- 如何在 python3 中将 OrderedDict 转换为常规字典 2022-01-01
- python-m http.server 443--使用SSL? 2022-01-01
- python check_output 失败,退出状态为 1,但 Popen 适用于相同的命令 2022-01-01