求問大神,調試問題。為什么我代碼跑起來顯示的是4ms,而第一名同學跑的是0.03ms
#coding=utf8
import time
def performance(unit):
? ? def fn(f):
? ? ? ? def print_time(*args, **kw):
? ? ? ? ? ? t1 = time.time()
? ? ? ? ? ? r= f(*args,**kw)
? ? ? ? ? ? t2 = time.time()
? ? ? ? ? ? t = (t2 - t1)*1000 if unit =='ms' else (t2 - t1)? ? #如果是ms,則*1000,如果不是則直接得到t2-t1
? ? ? ? ? ? print 'call %s() in %f %s' % ( f.__name__ , t, unit)
? ? ? ? ? ? return r
? ? ? ? return print_time
? ? return fn
@performance('ms')
def factorial(n):
? ? return reduce(lambda x,y: x*y, range(1, n+1))
print factorial(10)
def performance(unit):
? ? def perf_decorator(f):
? ? ? ? def wrapper(*args, **kw):
? ? ? ? ? ? t1 = time.time()
? ? ? ? ? ? r = f(*args, **kw)
? ? ? ? ? ? t2 = time.time()
? ? ? ? ? ? t = (t2 - t1)*1000 if unit =='ms' else (t2 - t1)
? ? ? ? ? ? print 'call %s() in %f %s'%(f.__name__, t, unit)
? ? ? ? ? ? return r
? ? ? ? return wrapper
? ? return perf_decorator
@performance('ms')??
def factorial(n):
? ? return reduce(lambda x,y: x*y, range(1, n+1))
print factorial(10)
2020-07-03
py3 和py2 改的地方還挺多的,尤其現在學的這塊,也不知道你改了運行出來后,代碼是不是一樣的了,我這上面自己寫的,下面是另一個同學的,但是在網頁運行的時候,得到的時間不一樣,而且差好遠。。我就很驚訝,也就是只有部分函數名不一樣而已呀
2020-06-30