为了账号安全,请及时绑定邮箱和手机立即绑定

求问大神,调试问题。为什么我代码跑起来显示的是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)


正在回答

2 回答

py3 和py2 改的地方还挺多的,尤其现在学的这块,也不知道你改了运行出来后,代码是不是一样的了,我这上面自己写的,下面是另一个同学的,但是在网页运行的时候,得到的时间不一样,而且差好远。。我就很惊讶,也就是只有部分函数名不一样而已呀

0 回复 有任何疑惑可以回复我~

http://img1.sycdn.imooc.com//5efb443d00013d7108350553.jpg我的电脑python3运行是0.0ms  我猜不同pc性能不一样 运行速度就不一样吧 这是我的想法 我小白一个 哈哈

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
python进阶
  • 参与学习       255665    人
  • 解答问题       2949    个

学习函数式、模块和面向对象编程,掌握Python高级程序设计

进入课程

求问大神,调试问题。为什么我代码跑起来显示的是4ms,而第一名同学跑的是0.03ms

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信