SORU
1 Ocak 2010, Cuma


Memoization nedir ve nasıl Python kullanabilir miyim?

Ben sadece Python başladı ve memoization ne ve nasıl kullanılacağı hakkında hiçbir fikrim yok. Ayrıca, basitleştirilmiş bir örnek alabilir miyim?

CEVAP
1 Ocak 2010, Cuma


Memoization etkili hatırlama anlamına gelir ("" - >"" ->muhtıra memoization hatırlanmak) yöntemini çağırır yöntem girişlerine dayalı sonuçlar ve daha sonra hatırladı sonuç döndürmek yerine, yine sonuç hesaplama. Yöntem sonuçlar için bir önbellek olarak düşünebilirsiniz. Daha fazla ayrıntı için, sayfaya bakın Cormen 365 et al., Algoritmalar (3e) giriş.

Hesaplama faktöriyel Python memoization kullanmak için basit bir örnek bu gibi bir şey olacaktır:

factorial_memo = {}
def factorial(k):
    if k < 2: return 1
    if not k in factorial_memo:
        factorial_memo[k] = k * factorial(k-1)
    return factorial_memo[k]

Çok daha karmaşık ve bir sınıfa memoization işlemi saklanması

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)
        return self.memo[args]

Sonra:

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

factorial = Memoize(factorial)

Bunu Paylaş:
  • Google+
  • E-Posta
Etiketler:

YORUMLAR

SPONSOR VİDEO

Rastgele Yazarlar

  • fast2hell

    fast2hell

    16 AĞUSTOS 2006
  • Jonathan Morrison

    Jonathan Mor

    24 Mart 2010
  • Vintendo Power

    Vintendo Pow

    2 Ocak 2007