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

  • Amir Parmar

    Amir Parmar

    25 Kasım 2010
  • humanHardDrive

    humanHardDri

    16 Mart 2011
  • Justin Davis

    Justin Davis

    14 Ocak 2008