2 callmexiaoqiu CallMeXiaoQiu 于 2016.09.09 20:57 提问

为什么下面两段python代码运行速度大不相同?

//python3.5

 def fact(n):
    if(n<=1):
        return 1;
    else:
        s=1;
        for i in range(1,n+1,1):
            s*=i;
    return s;

def fact_length(n):
    print(n,"!(length)=",len(str(fact(n))),'\n');

没有写递归,python中递归层数有限制,不便于后面测试!

切回正题:各位大神我用上面两段代码测试时发现,当测试数据为10000以上时,第二个函数的执行速度明显快于第一段,表示不解。第二段函数的中间还套着第一段函数,运行速度为啥比第一段还快?

猜测:是不是慢在输出上?当数据量大了输出很费时???我的猜测对吗?

求大神告知,先谢过了!

2个回答

oyljerry
oyljerry   Ds   Rxr 2016.09.09 21:42
已采纳

输出需要打印到管道,比较耗时

CallMeXiaoQiu
CallMeXiaoQiu 谢谢,能不能具体说下细节
大约一年之前 回复
u014559880
u014559880   2016.09.09 21:08

R U Kidding Us?

CallMeXiaoQiu
CallMeXiaoQiu win7系统8G内存,python3.5 idle开发环境
大约一年之前 回复
CallMeXiaoQiu
CallMeXiaoQiu 运行试试嘛?
大约一年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片