一行代码实现5!+4!+3!+2!+1!
想要一行代码实现5!+4!+3!+2!+1!?用Java、或者是C,我想应该比较难吧?不过在Python里面却非常的简单。
我们先看看用传统的方法怎么实现:
def do_sum_default(num):
"""默认计算 n! + (n-1)! + 2! + 1"""
num_list = map(lambda n: n + 1, range(num))
res = 0
for n in num_list:
calc_list = [n + 1 for n in range(n)]
res += reduce(lambda x, y: x * y, calc_list)
return res
精简后,代码为:
def do_sum_default(num):
"""默认计算 n! + (n-1)! + 2! + 1"""
num_list = map(lambda n: n + 1, range(num))
res = 0
for n in num_list:
calc_list = [n + 1 for n in range(n)]
res += reduce(lambda x, y: x * y, calc_list)
return res
-
在num值为5时:
print(timeit.timeit("do_sum_default(5)", setup="from __main__ import do_sum_default", number=1000)) print(timeit.timeit("do_sum(5)", setup="from __main__ import do_sum", number=1000))>>> 0.0152427193959 >>> 0.0210387074335 -
在num值为10时:
print(timeit.timeit("do_sum_default(10)", setup="from __main__ import do_sum_default", number=1000)) print(timeit.timeit("do_sum(10)", setup="from __main__ import do_sum", number=1000))>>> 0.0387806271467 >>> 0.0510969969647 -
在num值为100时:
print(timeit.timeit("do_sum_default(100)", setup="from __main__ import do_sum_default", number=1000)) print(timeit.timeit("do_sum(100)", setup="from __main__ import do_sum", number=1000))>>> 2.77467415551 >>> 3.34986541586
本文展示了如何使用Python一行代码实现求从5!到1!之和,并与传统方法进行了性能对比。强调了代码简洁性与执行效率之间的权衡,建议开发者综合考虑代码的易读性、易维护性和执行效率。

被折叠的 条评论
为什么被折叠?



