一行代碼實現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
結果很明顯,用傳統的方式執行速度要快得多,所以建議大家不要過於追求代碼的簡潔性,還要注意執行效率、以及代碼的易讀性、易維護性。