-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmemoize.py
33 lines (28 loc) · 1.05 KB
/
memoize.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
def memoize(fun):
"""A clever way to reduce the runtime on the Mystery HELL tests by
half"""
dictName = "__" + fun.__name__ + "_memoizer"
def func_wrap(self, *rest):
if rest not in self.__dict__[dictName]:
self.__dict__[dictName][rest] = fun(self, *rest)
return self.__dict__[dictName][rest]
if '__init__' not in fun.im_class.__dict__:
fun.im_class.__dict__['__init__'] = lambda *rest: None
oldInit = fun.im_class.__dict__['__init__']
def init_wrap(self, *rest):
self.__dict__[dictName] = {}
#print "Initializing %s" % dictName
return oldInit(self, *rest)
fun.im_class.__dict__['__init__'] = init_wrap
fun.im_class.__dict__[fun.__name__] = func_wrap
if __name__ == "__main__":
class testClass:
def foo(self, string):
print string
return string
memoize(testClass.foo)
obj = testClass()
print "->%s" % obj.foo("Hello")
print "->%s" % obj.foo("Hello")
print "->%s" % obj.foo("Gato")
print "->%s" % obj.foo("Gato")