CallMeXiaoQiu
2016-09-09 12:57 阅读 1.0k
已采纳

为什么下面两段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 2016-09-09 13:42

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

    点赞 1 评论 复制链接分享
  • u014559880 androiosymbian 2016-09-09 13:08

    R U Kidding Us?

    点赞 评论 复制链接分享

相关推荐