栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Python-什么是备忘录,如何在Python中使用备忘录?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Python-什么是备忘录,如何在Python中使用备忘录?

记忆有效地指基于方法输入记忆方法调用的结果(“记忆”→“备忘录”→要记忆),然后返回记忆的结果,而不是再次计算结果。你可以将其视为方法结果的缓存。有关更多详细信息,请参见第387页的Cormen等人的《算法简介》(3e)中的定义。

一个简单的示例,使用Python中的记忆来计算阶乘是这样的:

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]

你可能会变得更加复杂,并将备注过程封装到一个类中:

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中添加了一个称为“ 装饰器 ”的功能,使你现在只需编写以下代码即可完成同一操作:

@Memoizedef factorial(k):    if k < 2: return 1    return k * factorial(k - 1)


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/387027.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号